grpc 1.50.0-x86_64-linux → 1.52.0.pre2-x86_64-linux

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


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

Files changed (2569) hide show
  1. checksums.yaml +4 -4
  2. data/grpc_c.32-msvcrt.ruby +0 -0
  3. data/grpc_c.64-msvcrt.ruby +0 -0
  4. data/grpc_c.64-ucrt.ruby +0 -0
  5. data/src/ruby/ext/grpc/{ext-export-truffleruby.clang → ext-export-truffleruby-with-ruby-abi-version.clang} +0 -0
  6. data/src/ruby/ext/grpc/{ext-export-truffleruby.gcc → ext-export-truffleruby-with-ruby-abi-version.gcc} +0 -0
  7. data/src/ruby/ext/grpc/ext-export-with-ruby-abi-version.clang +2 -0
  8. data/src/ruby/ext/grpc/ext-export-with-ruby-abi-version.gcc +7 -0
  9. data/src/ruby/ext/grpc/ext-export.clang +0 -1
  10. data/src/ruby/ext/grpc/ext-export.gcc +1 -2
  11. data/src/ruby/ext/grpc/extconf.rb +47 -2
  12. data/src/ruby/ext/grpc/rb_call.c +1 -0
  13. data/src/ruby/ext/grpc/rb_channel.c +1 -0
  14. data/src/ruby/ext/grpc/rb_channel_args.c +1 -0
  15. data/src/ruby/ext/grpc/rb_compression_options.c +1 -1
  16. data/src/ruby/ext/grpc/rb_grpc.c +1 -0
  17. data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +38 -38
  18. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +59 -59
  19. data/src/ruby/lib/grpc/2.7/grpc_c.so +0 -0
  20. data/src/ruby/lib/grpc/3.0/grpc_c.so +0 -0
  21. data/src/ruby/lib/grpc/3.1/grpc_c.so +0 -0
  22. data/src/ruby/lib/grpc/{grpc_c.so → 3.2/grpc_c.so} +0 -0
  23. data/src/ruby/lib/grpc/generic/bidi_call.rb +2 -0
  24. data/src/ruby/lib/grpc/version.rb +1 -1
  25. data/src/ruby/spec/channel_spec.rb +0 -43
  26. data/src/ruby/spec/client_server_spec.rb +20 -8
  27. data/src/ruby/spec/generic/active_call_spec.rb +12 -3
  28. metadata +28 -2564
  29. data/.yardopts +0 -1
  30. data/Makefile +0 -3169
  31. data/include/grpc/byte_buffer.h +0 -27
  32. data/include/grpc/byte_buffer_reader.h +0 -26
  33. data/include/grpc/census.h +0 -40
  34. data/include/grpc/compression.h +0 -75
  35. data/include/grpc/event_engine/README.md +0 -38
  36. data/include/grpc/event_engine/endpoint_config.h +0 -49
  37. data/include/grpc/event_engine/event_engine.h +0 -446
  38. data/include/grpc/event_engine/internal/memory_allocator_impl.h +0 -68
  39. data/include/grpc/event_engine/memory_allocator.h +0 -211
  40. data/include/grpc/event_engine/memory_request.h +0 -57
  41. data/include/grpc/event_engine/port.h +0 -39
  42. data/include/grpc/event_engine/slice.h +0 -286
  43. data/include/grpc/event_engine/slice_buffer.h +0 -118
  44. data/include/grpc/fork.h +0 -26
  45. data/include/grpc/grpc.h +0 -605
  46. data/include/grpc/grpc_cronet.h +0 -38
  47. data/include/grpc/grpc_posix.h +0 -63
  48. data/include/grpc/grpc_security.h +0 -1270
  49. data/include/grpc/grpc_security_constants.h +0 -152
  50. data/include/grpc/impl/codegen/README.md +0 -22
  51. data/include/grpc/impl/codegen/atm.h +0 -97
  52. data/include/grpc/impl/codegen/atm_gcc_atomic.h +0 -84
  53. data/include/grpc/impl/codegen/atm_gcc_sync.h +0 -85
  54. data/include/grpc/impl/codegen/atm_windows.h +0 -132
  55. data/include/grpc/impl/codegen/byte_buffer.h +0 -103
  56. data/include/grpc/impl/codegen/byte_buffer_reader.h +0 -44
  57. data/include/grpc/impl/codegen/compression_types.h +0 -109
  58. data/include/grpc/impl/codegen/connectivity_state.h +0 -47
  59. data/include/grpc/impl/codegen/fork.h +0 -50
  60. data/include/grpc/impl/codegen/gpr_slice.h +0 -71
  61. data/include/grpc/impl/codegen/gpr_types.h +0 -62
  62. data/include/grpc/impl/codegen/grpc_types.h +0 -818
  63. data/include/grpc/impl/codegen/log.h +0 -112
  64. data/include/grpc/impl/codegen/port_platform.h +0 -782
  65. data/include/grpc/impl/codegen/propagation_bits.h +0 -54
  66. data/include/grpc/impl/codegen/slice.h +0 -132
  67. data/include/grpc/impl/codegen/status.h +0 -156
  68. data/include/grpc/impl/codegen/sync.h +0 -68
  69. data/include/grpc/impl/codegen/sync_abseil.h +0 -38
  70. data/include/grpc/impl/codegen/sync_custom.h +0 -40
  71. data/include/grpc/impl/codegen/sync_generic.h +0 -51
  72. data/include/grpc/impl/codegen/sync_posix.h +0 -54
  73. data/include/grpc/impl/codegen/sync_windows.h +0 -42
  74. data/include/grpc/load_reporting.h +0 -48
  75. data/include/grpc/module.modulemap +0 -64
  76. data/include/grpc/slice.h +0 -161
  77. data/include/grpc/slice_buffer.h +0 -84
  78. data/include/grpc/status.h +0 -26
  79. data/include/grpc/support/alloc.h +0 -52
  80. data/include/grpc/support/atm.h +0 -26
  81. data/include/grpc/support/atm_gcc_atomic.h +0 -26
  82. data/include/grpc/support/atm_gcc_sync.h +0 -26
  83. data/include/grpc/support/atm_windows.h +0 -26
  84. data/include/grpc/support/cpu.h +0 -44
  85. data/include/grpc/support/log.h +0 -26
  86. data/include/grpc/support/log_windows.h +0 -38
  87. data/include/grpc/support/port_platform.h +0 -24
  88. data/include/grpc/support/string_util.h +0 -51
  89. data/include/grpc/support/sync.h +0 -282
  90. data/include/grpc/support/sync_abseil.h +0 -26
  91. data/include/grpc/support/sync_custom.h +0 -26
  92. data/include/grpc/support/sync_generic.h +0 -26
  93. data/include/grpc/support/sync_posix.h +0 -26
  94. data/include/grpc/support/sync_windows.h +0 -26
  95. data/include/grpc/support/thd_id.h +0 -44
  96. data/include/grpc/support/time.h +0 -92
  97. data/include/grpc/support/workaround_list.h +0 -31
  98. data/src/core/ext/filters/census/grpc_context.cc +0 -42
  99. data/src/core/ext/filters/channel_idle/channel_idle_filter.cc +0 -309
  100. data/src/core/ext/filters/channel_idle/channel_idle_filter.h +0 -141
  101. data/src/core/ext/filters/channel_idle/idle_filter_state.cc +0 -96
  102. data/src/core/ext/filters/channel_idle/idle_filter_state.h +0 -68
  103. data/src/core/ext/filters/client_channel/backend_metric.cc +0 -84
  104. data/src/core/ext/filters/client_channel/backend_metric.h +0 -47
  105. data/src/core/ext/filters/client_channel/backup_poller.cc +0 -187
  106. data/src/core/ext/filters/client_channel/backup_poller.h +0 -40
  107. data/src/core/ext/filters/client_channel/channel_connectivity.cc +0 -242
  108. data/src/core/ext/filters/client_channel/client_channel.cc +0 -3208
  109. data/src/core/ext/filters/client_channel/client_channel.h +0 -627
  110. data/src/core/ext/filters/client_channel/client_channel_channelz.cc +0 -94
  111. data/src/core/ext/filters/client_channel/client_channel_channelz.h +0 -85
  112. data/src/core/ext/filters/client_channel/client_channel_factory.cc +0 -32
  113. data/src/core/ext/filters/client_channel/client_channel_factory.h +0 -46
  114. data/src/core/ext/filters/client_channel/client_channel_plugin.cc +0 -42
  115. data/src/core/ext/filters/client_channel/config_selector.cc +0 -60
  116. data/src/core/ext/filters/client_channel/config_selector.h +0 -155
  117. data/src/core/ext/filters/client_channel/connector.h +0 -84
  118. data/src/core/ext/filters/client_channel/dynamic_filters.cc +0 -202
  119. data/src/core/ext/filters/client_channel/dynamic_filters.h +0 -109
  120. data/src/core/ext/filters/client_channel/global_subchannel_pool.cc +0 -65
  121. data/src/core/ext/filters/client_channel/global_subchannel_pool.h +0 -63
  122. data/src/core/ext/filters/client_channel/health/health_check_client.cc +0 -176
  123. data/src/core/ext/filters/client_channel/health/health_check_client.h +0 -43
  124. data/src/core/ext/filters/client_channel/http_proxy.cc +0 -201
  125. data/src/core/ext/filters/client_channel/http_proxy.h +0 -52
  126. data/src/core/ext/filters/client_channel/lb_policy/address_filtering.cc +0 -101
  127. data/src/core/ext/filters/client_channel/lb_policy/address_filtering.h +0 -103
  128. data/src/core/ext/filters/client_channel/lb_policy/backend_metric_data.h +0 -49
  129. data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.cc +0 -320
  130. data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.h +0 -89
  131. data/src/core/ext/filters/client_channel/lb_policy/grpclb/client_load_reporting_filter.cc +0 -149
  132. data/src/core/ext/filters/client_channel/lb_policy/grpclb/client_load_reporting_filter.h +0 -30
  133. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +0 -1942
  134. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.h +0 -40
  135. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.cc +0 -89
  136. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.h +0 -41
  137. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_client_stats.cc +0 -92
  138. data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_client_stats.h +0 -82
  139. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.cc +0 -202
  140. data/src/core/ext/filters/client_channel/lb_policy/grpclb/load_balancer_api.h +0 -76
  141. data/src/core/ext/filters/client_channel/lb_policy/oob_backend_metric.cc +0 -416
  142. data/src/core/ext/filters/client_channel/lb_policy/oob_backend_metric.h +0 -57
  143. data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.cc +0 -1140
  144. data/src/core/ext/filters/client_channel/lb_policy/outlier_detection/outlier_detection.h +0 -94
  145. data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +0 -545
  146. data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +0 -954
  147. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.cc +0 -891
  148. data/src/core/ext/filters/client_channel/lb_policy/ring_hash/ring_hash.h +0 -47
  149. data/src/core/ext/filters/client_channel/lb_policy/rls/rls.cc +0 -2513
  150. data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +0 -531
  151. data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.h +0 -439
  152. data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +0 -775
  153. data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +0 -772
  154. data/src/core/ext/filters/client_channel/lb_policy/xds/xds.h +0 -66
  155. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_channel_args.h +0 -29
  156. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_impl.cc +0 -800
  157. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_manager.cc +0 -731
  158. data/src/core/ext/filters/client_channel/lb_policy/xds/xds_cluster_resolver.cc +0 -1300
  159. data/src/core/ext/filters/client_channel/local_subchannel_pool.cc +0 -60
  160. data/src/core/ext/filters/client_channel/local_subchannel_pool.h +0 -59
  161. data/src/core/ext/filters/client_channel/resolver/binder/binder_resolver.cc +0 -149
  162. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +0 -877
  163. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver.h +0 -91
  164. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_posix.cc +0 -116
  165. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +0 -883
  166. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +0 -1206
  167. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.h +0 -137
  168. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_posix.cc +0 -29
  169. data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_windows.cc +0 -35
  170. data/src/core/ext/filters/client_channel/resolver/dns/dns_resolver_selection.cc +0 -30
  171. data/src/core/ext/filters/client_channel/resolver/dns/dns_resolver_selection.h +0 -30
  172. data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.cc +0 -203
  173. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.cc +0 -370
  174. data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.h +0 -110
  175. data/src/core/ext/filters/client_channel/resolver/google_c2p/google_c2p_resolver.cc +0 -464
  176. data/src/core/ext/filters/client_channel/resolver/polling_resolver.cc +0 -259
  177. data/src/core/ext/filters/client_channel/resolver/polling_resolver.h +0 -123
  178. data/src/core/ext/filters/client_channel/resolver/sockaddr/sockaddr_resolver.cc +0 -193
  179. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +0 -1130
  180. data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.h +0 -30
  181. data/src/core/ext/filters/client_channel/resolver_result_parsing.cc +0 -188
  182. data/src/core/ext/filters/client_channel/resolver_result_parsing.h +0 -108
  183. data/src/core/ext/filters/client_channel/retry_filter.cc +0 -2683
  184. data/src/core/ext/filters/client_channel/retry_filter.h +0 -31
  185. data/src/core/ext/filters/client_channel/retry_service_config.cc +0 -324
  186. data/src/core/ext/filters/client_channel/retry_service_config.h +0 -108
  187. data/src/core/ext/filters/client_channel/retry_throttle.cc +0 -141
  188. data/src/core/ext/filters/client_channel/retry_throttle.h +0 -91
  189. data/src/core/ext/filters/client_channel/service_config_channel_arg_filter.cc +0 -174
  190. data/src/core/ext/filters/client_channel/subchannel.cc +0 -978
  191. data/src/core/ext/filters/client_channel/subchannel.h +0 -435
  192. data/src/core/ext/filters/client_channel/subchannel_interface_internal.h +0 -38
  193. data/src/core/ext/filters/client_channel/subchannel_pool_interface.cc +0 -66
  194. data/src/core/ext/filters/client_channel/subchannel_pool_interface.h +0 -100
  195. data/src/core/ext/filters/client_channel/subchannel_stream_client.cc +0 -471
  196. data/src/core/ext/filters/client_channel/subchannel_stream_client.h +0 -222
  197. data/src/core/ext/filters/deadline/deadline_filter.cc +0 -401
  198. data/src/core/ext/filters/deadline/deadline_filter.h +0 -93
  199. data/src/core/ext/filters/fault_injection/fault_injection_filter.cc +0 -279
  200. data/src/core/ext/filters/fault_injection/fault_injection_filter.h +0 -75
  201. data/src/core/ext/filters/fault_injection/service_config_parser.cc +0 -187
  202. data/src/core/ext/filters/fault_injection/service_config_parser.h +0 -104
  203. data/src/core/ext/filters/http/client/http_client_filter.cc +0 -159
  204. data/src/core/ext/filters/http/client/http_client_filter.h +0 -61
  205. data/src/core/ext/filters/http/client_authority_filter.cc +0 -90
  206. data/src/core/ext/filters/http/client_authority_filter.h +0 -56
  207. data/src/core/ext/filters/http/http_filters_plugin.cc +0 -97
  208. data/src/core/ext/filters/http/message_compress/message_compress_filter.cc +0 -332
  209. data/src/core/ext/filters/http/message_compress/message_compress_filter.h +0 -52
  210. data/src/core/ext/filters/http/message_compress/message_decompress_filter.cc +0 -322
  211. data/src/core/ext/filters/http/message_compress/message_decompress_filter.h +0 -32
  212. data/src/core/ext/filters/http/server/http_server_filter.cc +0 -160
  213. data/src/core/ext/filters/http/server/http_server_filter.h +0 -63
  214. data/src/core/ext/filters/message_size/message_size_filter.cc +0 -404
  215. data/src/core/ext/filters/message_size/message_size_filter.h +0 -83
  216. data/src/core/ext/filters/rbac/rbac_filter.cc +0 -174
  217. data/src/core/ext/filters/rbac/rbac_filter.h +0 -84
  218. data/src/core/ext/filters/rbac/rbac_service_config_parser.cc +0 -621
  219. data/src/core/ext/filters/rbac/rbac_service_config_parser.h +0 -85
  220. data/src/core/ext/filters/server_config_selector/server_config_selector.cc +0 -62
  221. data/src/core/ext/filters/server_config_selector/server_config_selector.h +0 -85
  222. data/src/core/ext/filters/server_config_selector/server_config_selector_filter.cc +0 -161
  223. data/src/core/ext/filters/server_config_selector/server_config_selector_filter.h +0 -33
  224. data/src/core/ext/transport/chttp2/alpn/alpn.cc +0 -45
  225. data/src/core/ext/transport/chttp2/alpn/alpn.h +0 -36
  226. data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +0 -438
  227. data/src/core/ext/transport/chttp2/client/chttp2_connector.h +0 -77
  228. data/src/core/ext/transport/chttp2/server/chttp2_server.cc +0 -1109
  229. data/src/core/ext/transport/chttp2/server/chttp2_server.h +0 -47
  230. data/src/core/ext/transport/chttp2/transport/bin_decoder.cc +0 -252
  231. data/src/core/ext/transport/chttp2/transport/bin_decoder.h +0 -58
  232. data/src/core/ext/transport/chttp2/transport/bin_encoder.cc +0 -232
  233. data/src/core/ext/transport/chttp2/transport/bin_encoder.h +0 -42
  234. data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +0 -3004
  235. data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +0 -77
  236. data/src/core/ext/transport/chttp2/transport/context_list.cc +0 -71
  237. data/src/core/ext/transport/chttp2/transport/context_list.h +0 -54
  238. data/src/core/ext/transport/chttp2/transport/decode_huff.cc +0 -287
  239. data/src/core/ext/transport/chttp2/transport/decode_huff.h +0 -1018
  240. data/src/core/ext/transport/chttp2/transport/flow_control.cc +0 -411
  241. data/src/core/ext/transport/chttp2/transport/flow_control.h +0 -385
  242. data/src/core/ext/transport/chttp2/transport/frame.h +0 -43
  243. data/src/core/ext/transport/chttp2/transport/frame_data.cc +0 -155
  244. data/src/core/ext/transport/chttp2/transport/frame_data.h +0 -60
  245. data/src/core/ext/transport/chttp2/transport/frame_goaway.cc +0 -190
  246. data/src/core/ext/transport/chttp2/transport/frame_goaway.h +0 -65
  247. data/src/core/ext/transport/chttp2/transport/frame_ping.cc +0 -136
  248. data/src/core/ext/transport/chttp2/transport/frame_ping.h +0 -49
  249. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.cc +0 -127
  250. data/src/core/ext/transport/chttp2/transport/frame_rst_stream.h +0 -54
  251. data/src/core/ext/transport/chttp2/transport/frame_settings.cc +0 -243
  252. data/src/core/ext/transport/chttp2/transport/frame_settings.h +0 -66
  253. data/src/core/ext/transport/chttp2/transport/frame_window_update.cc +0 -121
  254. data/src/core/ext/transport/chttp2/transport/frame_window_update.h +0 -46
  255. data/src/core/ext/transport/chttp2/transport/hpack_constants.h +0 -47
  256. data/src/core/ext/transport/chttp2/transport/hpack_encoder.cc +0 -668
  257. data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +0 -236
  258. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.cc +0 -88
  259. data/src/core/ext/transport/chttp2/transport/hpack_encoder_table.h +0 -80
  260. data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +0 -1390
  261. data/src/core/ext/transport/chttp2/transport/hpack_parser.h +0 -142
  262. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.cc +0 -246
  263. data/src/core/ext/transport/chttp2/transport/hpack_parser_table.h +0 -137
  264. data/src/core/ext/transport/chttp2/transport/http2_settings.cc +0 -62
  265. data/src/core/ext/transport/chttp2/transport/http2_settings.h +0 -60
  266. data/src/core/ext/transport/chttp2/transport/huffsyms.cc +0 -92
  267. data/src/core/ext/transport/chttp2/transport/huffsyms.h +0 -32
  268. data/src/core/ext/transport/chttp2/transport/internal.h +0 -787
  269. data/src/core/ext/transport/chttp2/transport/parsing.cc +0 -731
  270. data/src/core/ext/transport/chttp2/transport/stream_lists.cc +0 -216
  271. data/src/core/ext/transport/chttp2/transport/stream_map.cc +0 -177
  272. data/src/core/ext/transport/chttp2/transport/stream_map.h +0 -68
  273. data/src/core/ext/transport/chttp2/transport/varint.cc +0 -62
  274. data/src/core/ext/transport/chttp2/transport/varint.h +0 -73
  275. data/src/core/ext/transport/chttp2/transport/writing.cc +0 -683
  276. data/src/core/ext/transport/inproc/inproc_plugin.cc +0 -23
  277. data/src/core/ext/transport/inproc/inproc_transport.cc +0 -1292
  278. data/src/core/ext/transport/inproc/inproc_transport.h +0 -34
  279. data/src/core/ext/upb-generated/envoy/admin/v3/certs.upb.c +0 -117
  280. data/src/core/ext/upb-generated/envoy/admin/v3/certs.upb.h +0 -502
  281. data/src/core/ext/upb-generated/envoy/admin/v3/clusters.upb.c +0 -121
  282. data/src/core/ext/upb-generated/envoy/admin/v3/clusters.upb.h +0 -569
  283. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.c +0 -125
  284. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump.upb.h +0 -516
  285. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump_shared.upb.c +0 -352
  286. data/src/core/ext/upb-generated/envoy/admin/v3/config_dump_shared.upb.h +0 -1768
  287. data/src/core/ext/upb-generated/envoy/admin/v3/init_dump.upb.c +0 -56
  288. data/src/core/ext/upb-generated/envoy/admin/v3/init_dump.upb.h +0 -159
  289. data/src/core/ext/upb-generated/envoy/admin/v3/listeners.upb.c +0 -64
  290. data/src/core/ext/upb-generated/envoy/admin/v3/listeners.upb.h +0 -189
  291. data/src/core/ext/upb-generated/envoy/admin/v3/memory.upb.c +0 -46
  292. data/src/core/ext/upb-generated/envoy/admin/v3/memory.upb.h +0 -128
  293. data/src/core/ext/upb-generated/envoy/admin/v3/metrics.upb.c +0 -43
  294. data/src/core/ext/upb-generated/envoy/admin/v3/metrics.upb.h +0 -106
  295. data/src/core/ext/upb-generated/envoy/admin/v3/mutex_stats.upb.c +0 -43
  296. data/src/core/ext/upb-generated/envoy/admin/v3/mutex_stats.upb.h +0 -101
  297. data/src/core/ext/upb-generated/envoy/admin/v3/server_info.upb.c +0 -106
  298. data/src/core/ext/upb-generated/envoy/admin/v3/server_info.upb.h +0 -613
  299. data/src/core/ext/upb-generated/envoy/admin/v3/tap.upb.c +0 -48
  300. data/src/core/ext/upb-generated/envoy/admin/v3/tap.upb.h +0 -107
  301. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.c +0 -60
  302. data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.h +0 -81
  303. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.c +0 -53
  304. data/src/core/ext/upb-generated/envoy/annotations/resource.upb.h +0 -103
  305. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.c +0 -270
  306. data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.h +0 -1300
  307. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.c +0 -413
  308. data/src/core/ext/upb-generated/envoy/config/bootstrap/v3/bootstrap.upb.h +0 -2251
  309. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.c +0 -95
  310. data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.h +0 -394
  311. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.c +0 -544
  312. data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.h +0 -3066
  313. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.c +0 -48
  314. data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.h +0 -107
  315. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.c +0 -89
  316. data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.h +0 -549
  317. data/src/core/ext/upb-generated/envoy/config/common/matcher/v3/matcher.upb.c +0 -299
  318. data/src/core/ext/upb-generated/envoy/config/common/matcher/v3/matcher.upb.h +0 -1437
  319. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.c +0 -145
  320. data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.h +0 -664
  321. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.c +0 -49
  322. data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.h +0 -120
  323. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.c +0 -421
  324. data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.h +0 -1891
  325. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.c +0 -163
  326. data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.h +0 -806
  327. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.c +0 -47
  328. data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.h +0 -104
  329. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.c +0 -47
  330. data/src/core/ext/upb-generated/envoy/config/core/v3/extension.upb.h +0 -107
  331. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_method_list.upb.c +0 -58
  332. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_method_list.upb.h +0 -159
  333. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.c +0 -269
  334. data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.h +0 -1329
  335. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.c +0 -220
  336. data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.h +0 -1255
  337. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.c +0 -49
  338. data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.h +0 -126
  339. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.c +0 -323
  340. data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.h +0 -1759
  341. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.c +0 -40
  342. data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.h +0 -88
  343. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.c +0 -60
  344. data/src/core/ext/upb-generated/envoy/config/core/v3/resolver.upb.h +0 -177
  345. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.c +0 -47
  346. data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.h +0 -148
  347. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.c +0 -56
  348. data/src/core/ext/upb-generated/envoy/config/core/v3/substitution_format_string.upb.h +0 -182
  349. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.c +0 -48
  350. data/src/core/ext/upb-generated/envoy/config/core/v3/udp_socket_config.upb.h +0 -122
  351. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.c +0 -106
  352. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.h +0 -360
  353. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.c +0 -144
  354. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.h +0 -647
  355. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.c +0 -129
  356. data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.h +0 -588
  357. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.c +0 -46
  358. data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.h +0 -98
  359. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.c +0 -189
  360. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.h +0 -1041
  361. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.c +0 -186
  362. data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.h +0 -969
  363. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.c +0 -63
  364. data/src/core/ext/upb-generated/envoy/config/listener/v3/quic_config.upb.h +0 -238
  365. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.c +0 -59
  366. data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.h +0 -186
  367. data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.c +0 -53
  368. data/src/core/ext/upb-generated/envoy/config/metrics/v3/metrics_service.upb.h +0 -140
  369. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.c +0 -165
  370. data/src/core/ext/upb-generated/envoy/config/metrics/v3/stats.upb.h +0 -748
  371. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.c +0 -174
  372. data/src/core/ext/upb-generated/envoy/config/overload/v3/overload.upb.h +0 -757
  373. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.c +0 -221
  374. data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.h +0 -1094
  375. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.c +0 -86
  376. data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.h +0 -402
  377. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.c +0 -1096
  378. data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.h +0 -6440
  379. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.c +0 -79
  380. data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.h +0 -267
  381. data/src/core/ext/upb-generated/envoy/config/tap/v3/common.upb.c +0 -241
  382. data/src/core/ext/upb-generated/envoy/config/tap/v3/common.upb.h +0 -1191
  383. data/src/core/ext/upb-generated/envoy/config/trace/v3/datadog.upb.c +0 -44
  384. data/src/core/ext/upb-generated/envoy/config/trace/v3/datadog.upb.h +0 -92
  385. data/src/core/ext/upb-generated/envoy/config/trace/v3/dynamic_ot.upb.c +0 -49
  386. data/src/core/ext/upb-generated/envoy/config/trace/v3/dynamic_ot.upb.h +0 -107
  387. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.c +0 -63
  388. data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.h +0 -175
  389. data/src/core/ext/upb-generated/envoy/config/trace/v3/lightstep.upb.c +0 -52
  390. data/src/core/ext/upb-generated/envoy/config/trace/v3/lightstep.upb.h +0 -138
  391. data/src/core/ext/upb-generated/envoy/config/trace/v3/opencensus.upb.c +0 -63
  392. data/src/core/ext/upb-generated/envoy/config/trace/v3/opencensus.upb.h +0 -254
  393. data/src/core/ext/upb-generated/envoy/config/trace/v3/opentelemetry.upb.c +0 -46
  394. data/src/core/ext/upb-generated/envoy/config/trace/v3/opentelemetry.upb.h +0 -98
  395. data/src/core/ext/upb-generated/envoy/config/trace/v3/service.upb.c +0 -47
  396. data/src/core/ext/upb-generated/envoy/config/trace/v3/service.upb.h +0 -98
  397. data/src/core/ext/upb-generated/envoy/config/trace/v3/skywalking.upb.c +0 -69
  398. data/src/core/ext/upb-generated/envoy/config/trace/v3/skywalking.upb.h +0 -221
  399. data/src/core/ext/upb-generated/envoy/config/trace/v3/trace.upb.c +0 -33
  400. data/src/core/ext/upb-generated/envoy/config/trace/v3/trace.upb.h +0 -43
  401. data/src/core/ext/upb-generated/envoy/config/trace/v3/xray.upb.c +0 -71
  402. data/src/core/ext/upb-generated/envoy/config/trace/v3/xray.upb.h +0 -226
  403. data/src/core/ext/upb-generated/envoy/config/trace/v3/zipkin.upb.c +0 -54
  404. data/src/core/ext/upb-generated/envoy/config/trace/v3/zipkin.upb.h +0 -150
  405. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.c +0 -42
  406. data/src/core/ext/upb-generated/envoy/extensions/clusters/aggregate/v3/cluster.upb.h +0 -89
  407. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.c +0 -96
  408. data/src/core/ext/upb-generated/envoy/extensions/filters/common/fault/v3/fault.upb.h +0 -395
  409. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.c +0 -94
  410. data/src/core/ext/upb-generated/envoy/extensions/filters/http/fault/v3/fault.upb.h +0 -445
  411. data/src/core/ext/upb-generated/envoy/extensions/filters/http/rbac/v3/rbac.upb.c +0 -71
  412. data/src/core/ext/upb-generated/envoy/extensions/filters/http/rbac/v3/rbac.upb.h +0 -237
  413. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.c +0 -55
  414. data/src/core/ext/upb-generated/envoy/extensions/filters/http/router/v3/router.upb.h +0 -172
  415. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.c +0 -471
  416. data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +0 -2731
  417. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.c +0 -52
  418. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.upb.h +0 -168
  419. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.c +0 -46
  420. data/src/core/ext/upb-generated/envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.upb.h +0 -98
  421. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.c +0 -28
  422. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.h +0 -38
  423. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.c +0 -177
  424. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.h +0 -932
  425. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.c +0 -88
  426. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +0 -320
  427. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.c +0 -191
  428. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +0 -1063
  429. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.c +0 -62
  430. data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upb.h +0 -168
  431. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.c +0 -38
  432. data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.h +0 -74
  433. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.c +0 -280
  434. data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.h +0 -1375
  435. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.c +0 -68
  436. data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.h +0 -218
  437. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.c +0 -138
  438. data/src/core/ext/upb-generated/envoy/service/status/v3/csds.upb.h +0 -651
  439. data/src/core/ext/upb-generated/envoy/type/http/v3/cookie.upb.c +0 -48
  440. data/src/core/ext/upb-generated/envoy/type/http/v3/cookie.upb.h +0 -116
  441. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.c +0 -76
  442. data/src/core/ext/upb-generated/envoy/type/http/v3/path_transformation.upb.h +0 -265
  443. data/src/core/ext/upb-generated/envoy/type/matcher/v3/http_inputs.upb.c +0 -74
  444. data/src/core/ext/upb-generated/envoy/type/matcher/v3/http_inputs.upb.h +0 -230
  445. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.c +0 -62
  446. data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.h +0 -196
  447. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.c +0 -49
  448. data/src/core/ext/upb-generated/envoy/type/matcher/v3/node.upb.h +0 -121
  449. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.c +0 -48
  450. data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.h +0 -117
  451. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.c +0 -47
  452. data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.h +0 -104
  453. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.c +0 -80
  454. data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.h +0 -246
  455. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.c +0 -67
  456. data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.h +0 -226
  457. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.c +0 -60
  458. data/src/core/ext/upb-generated/envoy/type/matcher/v3/struct.upb.h +0 -178
  459. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.c +0 -78
  460. data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.h +0 -306
  461. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.c +0 -107
  462. data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.h +0 -457
  463. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.c +0 -107
  464. data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.h +0 -439
  465. data/src/core/ext/upb-generated/envoy/type/v3/hash_policy.upb.c +0 -66
  466. data/src/core/ext/upb-generated/envoy/type/v3/hash_policy.upb.h +0 -213
  467. data/src/core/ext/upb-generated/envoy/type/v3/http.upb.c +0 -26
  468. data/src/core/ext/upb-generated/envoy/type/v3/http.upb.h +0 -39
  469. data/src/core/ext/upb-generated/envoy/type/v3/http_status.upb.c +0 -42
  470. data/src/core/ext/upb-generated/envoy/type/v3/http_status.upb.h +0 -143
  471. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.c +0 -54
  472. data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.h +0 -147
  473. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.c +0 -66
  474. data/src/core/ext/upb-generated/envoy/type/v3/range.upb.h +0 -208
  475. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_strategy.upb.c +0 -63
  476. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_strategy.upb.h +0 -202
  477. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_unit.upb.c +0 -26
  478. data/src/core/ext/upb-generated/envoy/type/v3/ratelimit_unit.upb.h +0 -41
  479. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.c +0 -43
  480. data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.h +0 -101
  481. data/src/core/ext/upb-generated/envoy/type/v3/token_bucket.upb.c +0 -51
  482. data/src/core/ext/upb-generated/envoy/type/v3/token_bucket.upb.h +0 -131
  483. data/src/core/ext/upb-generated/google/api/annotations.upb.c +0 -40
  484. data/src/core/ext/upb-generated/google/api/annotations.upb.h +0 -53
  485. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.c +0 -271
  486. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/checked.upb.h +0 -1280
  487. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.c +0 -283
  488. data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.h +0 -1386
  489. data/src/core/ext/upb-generated/google/api/http.upb.c +0 -81
  490. data/src/core/ext/upb-generated/google/api/http.upb.h +0 -343
  491. data/src/core/ext/upb-generated/google/api/httpbody.upb.c +0 -46
  492. data/src/core/ext/upb-generated/google/api/httpbody.upb.h +0 -115
  493. data/src/core/ext/upb-generated/google/protobuf/any.upb.c +0 -40
  494. data/src/core/ext/upb-generated/google/protobuf/any.upb.h +0 -92
  495. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.c +0 -578
  496. data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.h +0 -3217
  497. data/src/core/ext/upb-generated/google/protobuf/duration.upb.c +0 -40
  498. data/src/core/ext/upb-generated/google/protobuf/duration.upb.h +0 -92
  499. data/src/core/ext/upb-generated/google/protobuf/empty.upb.c +0 -35
  500. data/src/core/ext/upb-generated/google/protobuf/empty.upb.h +0 -74
  501. data/src/core/ext/upb-generated/google/protobuf/struct.upb.c +0 -95
  502. data/src/core/ext/upb-generated/google/protobuf/struct.upb.h +0 -329
  503. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.c +0 -40
  504. data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.h +0 -92
  505. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.c +0 -127
  506. data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.h +0 -475
  507. data/src/core/ext/upb-generated/google/rpc/status.upb.c +0 -46
  508. data/src/core/ext/upb-generated/google/rpc/status.upb.h +0 -115
  509. data/src/core/ext/upb-generated/opencensus/proto/trace/v1/trace_config.upb.c +0 -84
  510. data/src/core/ext/upb-generated/opencensus/proto/trace/v1/trace_config.upb.h +0 -335
  511. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.c +0 -63
  512. data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.h +0 -188
  513. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.c +0 -240
  514. data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.h +0 -1173
  515. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.c +0 -57
  516. data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.h +0 -182
  517. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.c +0 -50
  518. data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.h +0 -139
  519. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.c +0 -161
  520. data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.h +0 -705
  521. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.c +0 -70
  522. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls.upb.h +0 -216
  523. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls_config.upb.c +0 -175
  524. data/src/core/ext/upb-generated/src/proto/grpc/lookup/v1/rls_config.upb.h +0 -792
  525. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.c +0 -110
  526. data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.h +0 -290
  527. data/src/core/ext/upb-generated/udpa/annotations/security.upb.c +0 -55
  528. data/src/core/ext/upb-generated/udpa/annotations/security.upb.h +0 -112
  529. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.c +0 -38
  530. data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.h +0 -46
  531. data/src/core/ext/upb-generated/udpa/annotations/status.upb.c +0 -54
  532. data/src/core/ext/upb-generated/udpa/annotations/status.upb.h +0 -119
  533. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.c +0 -53
  534. data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.h +0 -103
  535. data/src/core/ext/upb-generated/validate/validate.upb.c +0 -560
  536. data/src/core/ext/upb-generated/validate/validate.upb.h +0 -4105
  537. data/src/core/ext/upb-generated/xds/annotations/v3/migrate.upb.c +0 -110
  538. data/src/core/ext/upb-generated/xds/annotations/v3/migrate.upb.h +0 -290
  539. data/src/core/ext/upb-generated/xds/annotations/v3/security.upb.c +0 -55
  540. data/src/core/ext/upb-generated/xds/annotations/v3/security.upb.h +0 -112
  541. data/src/core/ext/upb-generated/xds/annotations/v3/sensitive.upb.c +0 -38
  542. data/src/core/ext/upb-generated/xds/annotations/v3/sensitive.upb.h +0 -46
  543. data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.c +0 -105
  544. data/src/core/ext/upb-generated/xds/annotations/v3/status.upb.h +0 -306
  545. data/src/core/ext/upb-generated/xds/annotations/v3/versioning.upb.c +0 -53
  546. data/src/core/ext/upb-generated/xds/annotations/v3/versioning.upb.h +0 -103
  547. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.c +0 -41
  548. data/src/core/ext/upb-generated/xds/core/v3/authority.upb.h +0 -83
  549. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.c +0 -66
  550. data/src/core/ext/upb-generated/xds/core/v3/collection_entry.upb.h +0 -208
  551. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.c +0 -56
  552. data/src/core/ext/upb-generated/xds/core/v3/context_params.upb.h +0 -119
  553. data/src/core/ext/upb-generated/xds/core/v3/extension.upb.c +0 -46
  554. data/src/core/ext/upb-generated/xds/core/v3/extension.upb.h +0 -107
  555. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.c +0 -49
  556. data/src/core/ext/upb-generated/xds/core/v3/resource.upb.h +0 -131
  557. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.c +0 -68
  558. data/src/core/ext/upb-generated/xds/core/v3/resource_locator.upb.h +0 -248
  559. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.c +0 -49
  560. data/src/core/ext/upb-generated/xds/core/v3/resource_name.upb.h +0 -125
  561. data/src/core/ext/upb-generated/xds/data/orca/v3/orca_load_report.upb.c +0 -73
  562. data/src/core/ext/upb-generated/xds/data/orca/v3/orca_load_report.upb.h +0 -191
  563. data/src/core/ext/upb-generated/xds/service/orca/v3/orca.upb.c +0 -47
  564. data/src/core/ext/upb-generated/xds/service/orca/v3/orca.upb.h +0 -113
  565. data/src/core/ext/upb-generated/xds/type/matcher/v3/matcher.upb.c +0 -207
  566. data/src/core/ext/upb-generated/xds/type/matcher/v3/matcher.upb.h +0 -914
  567. data/src/core/ext/upb-generated/xds/type/matcher/v3/regex.upb.c +0 -52
  568. data/src/core/ext/upb-generated/xds/type/matcher/v3/regex.upb.h +0 -151
  569. data/src/core/ext/upb-generated/xds/type/matcher/v3/string.upb.c +0 -65
  570. data/src/core/ext/upb-generated/xds/type/matcher/v3/string.upb.h +0 -226
  571. data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.c +0 -46
  572. data/src/core/ext/upb-generated/xds/type/v3/typed_struct.upb.h +0 -107
  573. data/src/core/ext/upbdefs-generated/envoy/admin/v3/certs.upbdefs.c +0 -84
  574. data/src/core/ext/upbdefs-generated/envoy/admin/v3/certs.upbdefs.h +0 -55
  575. data/src/core/ext/upbdefs-generated/envoy/admin/v3/clusters.upbdefs.c +0 -127
  576. data/src/core/ext/upbdefs-generated/envoy/admin/v3/clusters.upbdefs.h +0 -50
  577. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump.upbdefs.c +0 -102
  578. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump.upbdefs.h +0 -55
  579. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump_shared.upbdefs.c +0 -256
  580. data/src/core/ext/upbdefs-generated/envoy/admin/v3/config_dump_shared.upbdefs.h +0 -115
  581. data/src/core/ext/upbdefs-generated/envoy/admin/v3/init_dump.upbdefs.c +0 -43
  582. data/src/core/ext/upbdefs-generated/envoy/admin/v3/init_dump.upbdefs.h +0 -40
  583. data/src/core/ext/upbdefs-generated/envoy/admin/v3/listeners.upbdefs.c +0 -56
  584. data/src/core/ext/upbdefs-generated/envoy/admin/v3/listeners.upbdefs.h +0 -40
  585. data/src/core/ext/upbdefs-generated/envoy/admin/v3/memory.upbdefs.c +0 -49
  586. data/src/core/ext/upbdefs-generated/envoy/admin/v3/memory.upbdefs.h +0 -35
  587. data/src/core/ext/upbdefs-generated/envoy/admin/v3/metrics.upbdefs.c +0 -46
  588. data/src/core/ext/upbdefs-generated/envoy/admin/v3/metrics.upbdefs.h +0 -35
  589. data/src/core/ext/upbdefs-generated/envoy/admin/v3/mutex_stats.upbdefs.c +0 -46
  590. data/src/core/ext/upbdefs-generated/envoy/admin/v3/mutex_stats.upbdefs.h +0 -35
  591. data/src/core/ext/upbdefs-generated/envoy/admin/v3/server_info.upbdefs.c +0 -142
  592. data/src/core/ext/upbdefs-generated/envoy/admin/v3/server_info.upbdefs.h +0 -40
  593. data/src/core/ext/upbdefs-generated/envoy/admin/v3/tap.upbdefs.c +0 -51
  594. data/src/core/ext/upbdefs-generated/envoy/admin/v3/tap.upbdefs.h +0 -35
  595. data/src/core/ext/upbdefs-generated/envoy/annotations/deprecation.upbdefs.c +0 -48
  596. data/src/core/ext/upbdefs-generated/envoy/annotations/deprecation.upbdefs.h +0 -30
  597. data/src/core/ext/upbdefs-generated/envoy/annotations/resource.upbdefs.c +0 -38
  598. data/src/core/ext/upbdefs-generated/envoy/annotations/resource.upbdefs.h +0 -35
  599. data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.c +0 -222
  600. data/src/core/ext/upbdefs-generated/envoy/config/accesslog/v3/accesslog.upbdefs.h +0 -105
  601. data/src/core/ext/upbdefs-generated/envoy/config/bootstrap/v3/bootstrap.upbdefs.c +0 -397
  602. data/src/core/ext/upbdefs-generated/envoy/config/bootstrap/v3/bootstrap.upbdefs.h +0 -120
  603. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/circuit_breaker.upbdefs.c +0 -98
  604. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/circuit_breaker.upbdefs.h +0 -45
  605. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.c +0 -559
  606. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/cluster.upbdefs.h +0 -155
  607. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/filter.upbdefs.c +0 -51
  608. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/filter.upbdefs.h +0 -35
  609. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/outlier_detection.upbdefs.c +0 -138
  610. data/src/core/ext/upbdefs-generated/envoy/config/cluster/v3/outlier_detection.upbdefs.h +0 -35
  611. data/src/core/ext/upbdefs-generated/envoy/config/common/matcher/v3/matcher.upbdefs.c +0 -206
  612. data/src/core/ext/upbdefs-generated/envoy/config/common/matcher/v3/matcher.upbdefs.h +0 -105
  613. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/address.upbdefs.c +0 -112
  614. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/address.upbdefs.h +0 -65
  615. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/backoff.upbdefs.c +0 -54
  616. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/backoff.upbdefs.h +0 -35
  617. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.c +0 -270
  618. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/base.upbdefs.h +0 -150
  619. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.c +0 -168
  620. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/config_source.upbdefs.h +0 -65
  621. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/event_service_config.upbdefs.c +0 -53
  622. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/event_service_config.upbdefs.h +0 -35
  623. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/extension.upbdefs.c +0 -47
  624. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/extension.upbdefs.h +0 -35
  625. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_method_list.upbdefs.c +0 -53
  626. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_method_list.upbdefs.h +0 -40
  627. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_service.upbdefs.c +0 -235
  628. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/grpc_service.upbdefs.h +0 -100
  629. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.c +0 -228
  630. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/health_check.upbdefs.h +0 -75
  631. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/http_uri.upbdefs.c +0 -53
  632. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/http_uri.upbdefs.h +0 -35
  633. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.c +0 -300
  634. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/protocol.upbdefs.h +0 -110
  635. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/proxy_protocol.upbdefs.c +0 -41
  636. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/proxy_protocol.upbdefs.h +0 -35
  637. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/resolver.upbdefs.c +0 -55
  638. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/resolver.upbdefs.h +0 -40
  639. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/socket_option.upbdefs.c +0 -57
  640. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/socket_option.upbdefs.h +0 -35
  641. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/substitution_format_string.upbdefs.c +0 -70
  642. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/substitution_format_string.upbdefs.h +0 -35
  643. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/udp_socket_config.upbdefs.c +0 -49
  644. data/src/core/ext/upbdefs-generated/envoy/config/core/v3/udp_socket_config.upbdefs.h +0 -35
  645. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint.upbdefs.c +0 -99
  646. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint.upbdefs.h +0 -50
  647. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint_components.upbdefs.c +0 -128
  648. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/endpoint_components.upbdefs.h +0 -60
  649. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/load_report.upbdefs.c +0 -136
  650. data/src/core/ext/upbdefs-generated/envoy/config/endpoint/v3/load_report.upbdefs.h +0 -55
  651. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/api_listener.upbdefs.c +0 -48
  652. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/api_listener.upbdefs.h +0 -35
  653. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.c +0 -220
  654. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener.upbdefs.h +0 -65
  655. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener_components.upbdefs.c +0 -190
  656. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/listener_components.upbdefs.h +0 -65
  657. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/quic_config.upbdefs.c +0 -88
  658. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/quic_config.upbdefs.h +0 -35
  659. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/udp_listener_config.upbdefs.c +0 -71
  660. data/src/core/ext/upbdefs-generated/envoy/config/listener/v3/udp_listener_config.upbdefs.h +0 -40
  661. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/metrics_service.upbdefs.c +0 -69
  662. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/metrics_service.upbdefs.h +0 -35
  663. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/stats.upbdefs.c +0 -125
  664. data/src/core/ext/upbdefs-generated/envoy/config/metrics/v3/stats.upbdefs.h +0 -70
  665. data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.c +0 -134
  666. data/src/core/ext/upbdefs-generated/envoy/config/overload/v3/overload.upbdefs.h +0 -75
  667. data/src/core/ext/upbdefs-generated/envoy/config/rbac/v3/rbac.upbdefs.c +0 -194
  668. data/src/core/ext/upbdefs-generated/envoy/config/rbac/v3/rbac.upbdefs.h +0 -75
  669. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.c +0 -112
  670. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route.upbdefs.h +0 -40
  671. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.c +0 -939
  672. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/route_components.upbdefs.h +0 -305
  673. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/scoped_route.upbdefs.c +0 -77
  674. data/src/core/ext/upbdefs-generated/envoy/config/route/v3/scoped_route.upbdefs.h +0 -45
  675. data/src/core/ext/upbdefs-generated/envoy/config/tap/v3/common.upbdefs.c +0 -199
  676. data/src/core/ext/upbdefs-generated/envoy/config/tap/v3/common.upbdefs.h +0 -90
  677. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/datadog.upbdefs.c +0 -54
  678. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/datadog.upbdefs.h +0 -35
  679. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/dynamic_ot.upbdefs.c +0 -57
  680. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/dynamic_ot.upbdefs.h +0 -35
  681. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/http_tracer.upbdefs.c +0 -57
  682. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/http_tracer.upbdefs.h +0 -40
  683. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/lightstep.upbdefs.c +0 -72
  684. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/lightstep.upbdefs.h +0 -35
  685. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opencensus.upbdefs.c +0 -99
  686. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opencensus.upbdefs.h +0 -35
  687. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opentelemetry.upbdefs.c +0 -47
  688. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/opentelemetry.upbdefs.h +0 -35
  689. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/service.upbdefs.c +0 -52
  690. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/service.upbdefs.h +0 -35
  691. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/skywalking.upbdefs.c +0 -71
  692. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/skywalking.upbdefs.h +0 -40
  693. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/trace.upbdefs.c +0 -61
  694. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/trace.upbdefs.h +0 -30
  695. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/xray.upbdefs.c +0 -75
  696. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/xray.upbdefs.h +0 -40
  697. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/zipkin.upbdefs.c +0 -77
  698. data/src/core/ext/upbdefs-generated/envoy/config/trace/v3/zipkin.upbdefs.h +0 -35
  699. data/src/core/ext/upbdefs-generated/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.c +0 -50
  700. data/src/core/ext/upbdefs-generated/envoy/extensions/clusters/aggregate/v3/cluster.upbdefs.h +0 -35
  701. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/common/fault/v3/fault.upbdefs.c +0 -92
  702. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/common/fault/v3/fault.upbdefs.h +0 -55
  703. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/fault/v3/fault.upbdefs.c +0 -117
  704. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/fault/v3/fault.upbdefs.h +0 -45
  705. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.c +0 -80
  706. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/rbac/v3/rbac.upbdefs.h +0 -40
  707. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/router/v3/router.upbdefs.c +0 -78
  708. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/http/router/v3/router.upbdefs.h +0 -35
  709. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.c +0 -562
  710. data/src/core/ext/upbdefs-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upbdefs.h +0 -130
  711. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.c +0 -48
  712. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/cert.upbdefs.h +0 -30
  713. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.c +0 -213
  714. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/common.upbdefs.h +0 -65
  715. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.c +0 -91
  716. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/secret.upbdefs.h +0 -45
  717. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.c +0 -254
  718. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls.upbdefs.h +0 -65
  719. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.c +0 -58
  720. data/src/core/ext/upbdefs-generated/envoy/extensions/transport_sockets/tls/v3/tls_spiffe_validator_config.upbdefs.h +0 -40
  721. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/ads.upbdefs.c +0 -58
  722. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/ads.upbdefs.h +0 -35
  723. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.c +0 -197
  724. data/src/core/ext/upbdefs-generated/envoy/service/discovery/v3/discovery.upbdefs.h +0 -100
  725. data/src/core/ext/upbdefs-generated/envoy/service/load_stats/v3/lrs.upbdefs.c +0 -76
  726. data/src/core/ext/upbdefs-generated/envoy/service/load_stats/v3/lrs.upbdefs.h +0 -40
  727. data/src/core/ext/upbdefs-generated/envoy/service/status/v3/csds.upbdefs.c +0 -153
  728. data/src/core/ext/upbdefs-generated/envoy/service/status/v3/csds.upbdefs.h +0 -55
  729. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/cookie.upbdefs.c +0 -46
  730. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/cookie.upbdefs.h +0 -35
  731. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/path_transformation.upbdefs.c +0 -56
  732. data/src/core/ext/upbdefs-generated/envoy/type/http/v3/path_transformation.upbdefs.h +0 -50
  733. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/http_inputs.upbdefs.c +0 -52
  734. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/http_inputs.upbdefs.h +0 -50
  735. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/metadata.upbdefs.c +0 -61
  736. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/metadata.upbdefs.h +0 -40
  737. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/node.upbdefs.c +0 -54
  738. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/node.upbdefs.h +0 -35
  739. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/number.upbdefs.c +0 -52
  740. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/number.upbdefs.h +0 -35
  741. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/path.upbdefs.c +0 -51
  742. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/path.upbdefs.h +0 -35
  743. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/regex.upbdefs.c +0 -71
  744. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/regex.upbdefs.h +0 -45
  745. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/string.upbdefs.c +0 -65
  746. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/string.upbdefs.h +0 -40
  747. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/struct.upbdefs.c +0 -58
  748. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/struct.upbdefs.h +0 -40
  749. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/value.upbdefs.c +0 -75
  750. data/src/core/ext/upbdefs-generated/envoy/type/matcher/v3/value.upbdefs.h +0 -45
  751. data/src/core/ext/upbdefs-generated/envoy/type/metadata/v3/metadata.upbdefs.c +0 -78
  752. data/src/core/ext/upbdefs-generated/envoy/type/metadata/v3/metadata.upbdefs.h +0 -65
  753. data/src/core/ext/upbdefs-generated/envoy/type/tracing/v3/custom_tag.upbdefs.c +0 -85
  754. data/src/core/ext/upbdefs-generated/envoy/type/tracing/v3/custom_tag.upbdefs.h +0 -55
  755. data/src/core/ext/upbdefs-generated/envoy/type/v3/hash_policy.upbdefs.c +0 -53
  756. data/src/core/ext/upbdefs-generated/envoy/type/v3/hash_policy.upbdefs.h +0 -45
  757. data/src/core/ext/upbdefs-generated/envoy/type/v3/http.upbdefs.c +0 -36
  758. data/src/core/ext/upbdefs-generated/envoy/type/v3/http.upbdefs.h +0 -30
  759. data/src/core/ext/upbdefs-generated/envoy/type/v3/http_status.upbdefs.c +0 -94
  760. data/src/core/ext/upbdefs-generated/envoy/type/v3/http_status.upbdefs.h +0 -35
  761. data/src/core/ext/upbdefs-generated/envoy/type/v3/percent.upbdefs.c +0 -54
  762. data/src/core/ext/upbdefs-generated/envoy/type/v3/percent.upbdefs.h +0 -40
  763. data/src/core/ext/upbdefs-generated/envoy/type/v3/range.upbdefs.c +0 -48
  764. data/src/core/ext/upbdefs-generated/envoy/type/v3/range.upbdefs.h +0 -45
  765. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_strategy.upbdefs.c +0 -69
  766. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_strategy.upbdefs.h +0 -40
  767. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_unit.upbdefs.c +0 -38
  768. data/src/core/ext/upbdefs-generated/envoy/type/v3/ratelimit_unit.upbdefs.h +0 -30
  769. data/src/core/ext/upbdefs-generated/envoy/type/v3/semantic_version.upbdefs.c +0 -44
  770. data/src/core/ext/upbdefs-generated/envoy/type/v3/semantic_version.upbdefs.h +0 -35
  771. data/src/core/ext/upbdefs-generated/envoy/type/v3/token_bucket.upbdefs.c +0 -57
  772. data/src/core/ext/upbdefs-generated/envoy/type/v3/token_bucket.upbdefs.h +0 -35
  773. data/src/core/ext/upbdefs-generated/google/api/annotations.upbdefs.c +0 -40
  774. data/src/core/ext/upbdefs-generated/google/api/annotations.upbdefs.h +0 -30
  775. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/checked.upbdefs.c +0 -154
  776. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/checked.upbdefs.h +0 -95
  777. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/syntax.upbdefs.c +0 -153
  778. data/src/core/ext/upbdefs-generated/google/api/expr/v1alpha1/syntax.upbdefs.h +0 -100
  779. data/src/core/ext/upbdefs-generated/google/api/http.upbdefs.c +0 -52
  780. data/src/core/ext/upbdefs-generated/google/api/http.upbdefs.h +0 -45
  781. data/src/core/ext/upbdefs-generated/google/api/httpbody.upbdefs.c +0 -39
  782. data/src/core/ext/upbdefs-generated/google/api/httpbody.upbdefs.h +0 -35
  783. data/src/core/ext/upbdefs-generated/google/protobuf/any.upbdefs.c +0 -34
  784. data/src/core/ext/upbdefs-generated/google/protobuf/any.upbdefs.h +0 -35
  785. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.c +0 -331
  786. data/src/core/ext/upbdefs-generated/google/protobuf/descriptor.upbdefs.h +0 -165
  787. data/src/core/ext/upbdefs-generated/google/protobuf/duration.upbdefs.c +0 -35
  788. data/src/core/ext/upbdefs-generated/google/protobuf/duration.upbdefs.h +0 -35
  789. data/src/core/ext/upbdefs-generated/google/protobuf/empty.upbdefs.c +0 -32
  790. data/src/core/ext/upbdefs-generated/google/protobuf/empty.upbdefs.h +0 -35
  791. data/src/core/ext/upbdefs-generated/google/protobuf/struct.upbdefs.c +0 -54
  792. data/src/core/ext/upbdefs-generated/google/protobuf/struct.upbdefs.h +0 -50
  793. data/src/core/ext/upbdefs-generated/google/protobuf/timestamp.upbdefs.c +0 -35
  794. data/src/core/ext/upbdefs-generated/google/protobuf/timestamp.upbdefs.h +0 -35
  795. data/src/core/ext/upbdefs-generated/google/protobuf/wrappers.upbdefs.c +0 -45
  796. data/src/core/ext/upbdefs-generated/google/protobuf/wrappers.upbdefs.h +0 -75
  797. data/src/core/ext/upbdefs-generated/google/rpc/status.upbdefs.c +0 -37
  798. data/src/core/ext/upbdefs-generated/google/rpc/status.upbdefs.h +0 -35
  799. data/src/core/ext/upbdefs-generated/opencensus/proto/trace/v1/trace_config.upbdefs.c +0 -67
  800. data/src/core/ext/upbdefs-generated/opencensus/proto/trace/v1/trace_config.upbdefs.h +0 -50
  801. data/src/core/ext/upbdefs-generated/src/proto/grpc/lookup/v1/rls_config.upbdefs.c +0 -99
  802. data/src/core/ext/upbdefs-generated/src/proto/grpc/lookup/v1/rls_config.upbdefs.h +0 -75
  803. data/src/core/ext/upbdefs-generated/udpa/annotations/migrate.upbdefs.c +0 -62
  804. data/src/core/ext/upbdefs-generated/udpa/annotations/migrate.upbdefs.h +0 -45
  805. data/src/core/ext/upbdefs-generated/udpa/annotations/security.upbdefs.c +0 -47
  806. data/src/core/ext/upbdefs-generated/udpa/annotations/security.upbdefs.h +0 -35
  807. data/src/core/ext/upbdefs-generated/udpa/annotations/sensitive.upbdefs.c +0 -34
  808. data/src/core/ext/upbdefs-generated/udpa/annotations/sensitive.upbdefs.h +0 -30
  809. data/src/core/ext/upbdefs-generated/udpa/annotations/status.upbdefs.c +0 -46
  810. data/src/core/ext/upbdefs-generated/udpa/annotations/status.upbdefs.h +0 -35
  811. data/src/core/ext/upbdefs-generated/udpa/annotations/versioning.upbdefs.c +0 -39
  812. data/src/core/ext/upbdefs-generated/udpa/annotations/versioning.upbdefs.h +0 -35
  813. data/src/core/ext/upbdefs-generated/validate/validate.upbdefs.c +0 -283
  814. data/src/core/ext/upbdefs-generated/validate/validate.upbdefs.h +0 -145
  815. data/src/core/ext/upbdefs-generated/xds/annotations/v3/migrate.upbdefs.c +0 -63
  816. data/src/core/ext/upbdefs-generated/xds/annotations/v3/migrate.upbdefs.h +0 -45
  817. data/src/core/ext/upbdefs-generated/xds/annotations/v3/security.upbdefs.c +0 -47
  818. data/src/core/ext/upbdefs-generated/xds/annotations/v3/security.upbdefs.h +0 -35
  819. data/src/core/ext/upbdefs-generated/xds/annotations/v3/sensitive.upbdefs.c +0 -35
  820. data/src/core/ext/upbdefs-generated/xds/annotations/v3/sensitive.upbdefs.h +0 -30
  821. data/src/core/ext/upbdefs-generated/xds/annotations/v3/status.upbdefs.c +0 -64
  822. data/src/core/ext/upbdefs-generated/xds/annotations/v3/status.upbdefs.h +0 -50
  823. data/src/core/ext/upbdefs-generated/xds/annotations/v3/versioning.upbdefs.c +0 -40
  824. data/src/core/ext/upbdefs-generated/xds/annotations/v3/versioning.upbdefs.h +0 -35
  825. data/src/core/ext/upbdefs-generated/xds/core/v3/authority.upbdefs.c +0 -38
  826. data/src/core/ext/upbdefs-generated/xds/core/v3/authority.upbdefs.h +0 -35
  827. data/src/core/ext/upbdefs-generated/xds/core/v3/collection_entry.upbdefs.c +0 -56
  828. data/src/core/ext/upbdefs-generated/xds/core/v3/collection_entry.upbdefs.h +0 -40
  829. data/src/core/ext/upbdefs-generated/xds/core/v3/context_params.upbdefs.c +0 -39
  830. data/src/core/ext/upbdefs-generated/xds/core/v3/context_params.upbdefs.h +0 -40
  831. data/src/core/ext/upbdefs-generated/xds/core/v3/extension.upbdefs.c +0 -41
  832. data/src/core/ext/upbdefs-generated/xds/core/v3/extension.upbdefs.h +0 -35
  833. data/src/core/ext/upbdefs-generated/xds/core/v3/resource.upbdefs.c +0 -45
  834. data/src/core/ext/upbdefs-generated/xds/core/v3/resource.upbdefs.h +0 -35
  835. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_locator.upbdefs.c +0 -61
  836. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_locator.upbdefs.h +0 -40
  837. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_name.upbdefs.c +0 -46
  838. data/src/core/ext/upbdefs-generated/xds/core/v3/resource_name.upbdefs.h +0 -35
  839. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/matcher.upbdefs.c +0 -126
  840. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/matcher.upbdefs.h +0 -80
  841. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/regex.upbdefs.c +0 -40
  842. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/regex.upbdefs.h +0 -40
  843. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/string.upbdefs.c +0 -52
  844. data/src/core/ext/upbdefs-generated/xds/type/matcher/v3/string.upbdefs.h +0 -40
  845. data/src/core/ext/upbdefs-generated/xds/type/v3/typed_struct.upbdefs.c +0 -40
  846. data/src/core/ext/upbdefs-generated/xds/type/v3/typed_struct.upbdefs.h +0 -35
  847. data/src/core/ext/xds/certificate_provider_store.cc +0 -159
  848. data/src/core/ext/xds/certificate_provider_store.h +0 -138
  849. data/src/core/ext/xds/file_watcher_certificate_provider_factory.cc +0 -153
  850. data/src/core/ext/xds/file_watcher_certificate_provider_factory.h +0 -77
  851. data/src/core/ext/xds/upb_utils.h +0 -45
  852. data/src/core/ext/xds/xds_api.cc +0 -699
  853. data/src/core/ext/xds/xds_api.h +0 -196
  854. data/src/core/ext/xds/xds_bootstrap.cc +0 -38
  855. data/src/core/ext/xds/xds_bootstrap.h +0 -89
  856. data/src/core/ext/xds/xds_bootstrap_grpc.cc +0 -370
  857. data/src/core/ext/xds/xds_bootstrap_grpc.h +0 -169
  858. data/src/core/ext/xds/xds_certificate_provider.cc +0 -419
  859. data/src/core/ext/xds/xds_certificate_provider.h +0 -183
  860. data/src/core/ext/xds/xds_channel_args.h +0 -32
  861. data/src/core/ext/xds/xds_channel_stack_modifier.cc +0 -120
  862. data/src/core/ext/xds/xds_channel_stack_modifier.h +0 -65
  863. data/src/core/ext/xds/xds_client.cc +0 -2000
  864. data/src/core/ext/xds/xds_client.h +0 -336
  865. data/src/core/ext/xds/xds_client_grpc.cc +0 -229
  866. data/src/core/ext/xds/xds_client_grpc.h +0 -79
  867. data/src/core/ext/xds/xds_client_stats.cc +0 -159
  868. data/src/core/ext/xds/xds_client_stats.h +0 -242
  869. data/src/core/ext/xds/xds_cluster.cc +0 -551
  870. data/src/core/ext/xds/xds_cluster.h +0 -120
  871. data/src/core/ext/xds/xds_cluster_specifier_plugin.cc +0 -149
  872. data/src/core/ext/xds/xds_cluster_specifier_plugin.h +0 -73
  873. data/src/core/ext/xds/xds_common_types.cc +0 -434
  874. data/src/core/ext/xds/xds_common_types.h +0 -102
  875. data/src/core/ext/xds/xds_endpoint.cc +0 -383
  876. data/src/core/ext/xds/xds_endpoint.h +0 -142
  877. data/src/core/ext/xds/xds_http_fault_filter.cc +0 -222
  878. data/src/core/ext/xds/xds_http_fault_filter.h +0 -66
  879. data/src/core/ext/xds/xds_http_filters.cc +0 -129
  880. data/src/core/ext/xds/xds_http_filters.h +0 -133
  881. data/src/core/ext/xds/xds_http_rbac_filter.cc +0 -560
  882. data/src/core/ext/xds/xds_http_rbac_filter.h +0 -61
  883. data/src/core/ext/xds/xds_lb_policy_registry.cc +0 -290
  884. data/src/core/ext/xds/xds_lb_policy_registry.h +0 -72
  885. data/src/core/ext/xds/xds_listener.cc +0 -1102
  886. data/src/core/ext/xds/xds_listener.h +0 -228
  887. data/src/core/ext/xds/xds_resource_type.cc +0 -33
  888. data/src/core/ext/xds/xds_resource_type.h +0 -112
  889. data/src/core/ext/xds/xds_resource_type_impl.h +0 -91
  890. data/src/core/ext/xds/xds_route_config.cc +0 -1152
  891. data/src/core/ext/xds/xds_route_config.h +0 -241
  892. data/src/core/ext/xds/xds_routing.cc +0 -263
  893. data/src/core/ext/xds/xds_routing.h +0 -104
  894. data/src/core/ext/xds/xds_server_config_fetcher.cc +0 -1360
  895. data/src/core/ext/xds/xds_transport.h +0 -86
  896. data/src/core/ext/xds/xds_transport_grpc.cc +0 -357
  897. data/src/core/ext/xds/xds_transport_grpc.h +0 -135
  898. data/src/core/lib/address_utils/parse_address.cc +0 -339
  899. data/src/core/lib/address_utils/parse_address.h +0 -86
  900. data/src/core/lib/address_utils/sockaddr_utils.cc +0 -443
  901. data/src/core/lib/address_utils/sockaddr_utils.h +0 -100
  902. data/src/core/lib/avl/avl.h +0 -482
  903. data/src/core/lib/backoff/backoff.cc +0 -47
  904. data/src/core/lib/backoff/backoff.h +0 -89
  905. data/src/core/lib/channel/call_finalization.h +0 -88
  906. data/src/core/lib/channel/call_tracer.h +0 -94
  907. data/src/core/lib/channel/channel_args.cc +0 -626
  908. data/src/core/lib/channel/channel_args.h +0 -529
  909. data/src/core/lib/channel/channel_args_preconditioning.cc +0 -43
  910. data/src/core/lib/channel/channel_args_preconditioning.h +0 -62
  911. data/src/core/lib/channel/channel_fwd.h +0 -26
  912. data/src/core/lib/channel/channel_stack.cc +0 -311
  913. data/src/core/lib/channel/channel_stack.h +0 -381
  914. data/src/core/lib/channel/channel_stack_builder.cc +0 -54
  915. data/src/core/lib/channel/channel_stack_builder.h +0 -112
  916. data/src/core/lib/channel/channel_stack_builder_impl.cc +0 -95
  917. data/src/core/lib/channel/channel_stack_builder_impl.h +0 -46
  918. data/src/core/lib/channel/channel_trace.cc +0 -184
  919. data/src/core/lib/channel/channel_trace.h +0 -138
  920. data/src/core/lib/channel/channelz.cc +0 -583
  921. data/src/core/lib/channel/channelz.h +0 -374
  922. data/src/core/lib/channel/channelz_registry.cc +0 -277
  923. data/src/core/lib/channel/channelz_registry.h +0 -100
  924. data/src/core/lib/channel/connected_channel.cc +0 -241
  925. data/src/core/lib/channel/connected_channel.h +0 -36
  926. data/src/core/lib/channel/context.h +0 -63
  927. data/src/core/lib/channel/promise_based_filter.cc +0 -1262
  928. data/src/core/lib/channel/promise_based_filter.h +0 -571
  929. data/src/core/lib/channel/status_util.cc +0 -138
  930. data/src/core/lib/channel/status_util.h +0 -74
  931. data/src/core/lib/compression/compression.cc +0 -96
  932. data/src/core/lib/compression/compression_internal.cc +0 -249
  933. data/src/core/lib/compression/compression_internal.h +0 -93
  934. data/src/core/lib/compression/message_compress.cc +0 -194
  935. data/src/core/lib/compression/message_compress.h +0 -39
  936. data/src/core/lib/config/core_configuration.cc +0 -111
  937. data/src/core/lib/config/core_configuration.h +0 -243
  938. data/src/core/lib/debug/stats.cc +0 -165
  939. data/src/core/lib/debug/stats.h +0 -70
  940. data/src/core/lib/debug/stats_data.cc +0 -190
  941. data/src/core/lib/debug/stats_data.h +0 -151
  942. data/src/core/lib/debug/trace.cc +0 -153
  943. data/src/core/lib/debug/trace.h +0 -133
  944. data/src/core/lib/event_engine/channel_args_endpoint_config.cc +0 -40
  945. data/src/core/lib/event_engine/channel_args_endpoint_config.h +0 -49
  946. data/src/core/lib/event_engine/default_event_engine.cc +0 -71
  947. data/src/core/lib/event_engine/default_event_engine.h +0 -37
  948. data/src/core/lib/event_engine/default_event_engine_factory.cc +0 -50
  949. data/src/core/lib/event_engine/default_event_engine_factory.h +0 -33
  950. data/src/core/lib/event_engine/executor/executor.h +0 -38
  951. data/src/core/lib/event_engine/executor/threaded_executor.cc +0 -36
  952. data/src/core/lib/event_engine/executor/threaded_executor.h +0 -44
  953. data/src/core/lib/event_engine/forkable.cc +0 -101
  954. data/src/core/lib/event_engine/forkable.h +0 -61
  955. data/src/core/lib/event_engine/handle_containers.h +0 -67
  956. data/src/core/lib/event_engine/memory_allocator.cc +0 -74
  957. data/src/core/lib/event_engine/poller.h +0 -56
  958. data/src/core/lib/event_engine/posix_engine/posix_engine.cc +0 -142
  959. data/src/core/lib/event_engine/posix_engine/posix_engine.h +0 -121
  960. data/src/core/lib/event_engine/posix_engine/timer.cc +0 -311
  961. data/src/core/lib/event_engine/posix_engine/timer.h +0 -193
  962. data/src/core/lib/event_engine/posix_engine/timer_heap.cc +0 -107
  963. data/src/core/lib/event_engine/posix_engine/timer_heap.h +0 -56
  964. data/src/core/lib/event_engine/posix_engine/timer_manager.cc +0 -311
  965. data/src/core/lib/event_engine/posix_engine/timer_manager.h +0 -142
  966. data/src/core/lib/event_engine/resolved_address.cc +0 -41
  967. data/src/core/lib/event_engine/slice.cc +0 -102
  968. data/src/core/lib/event_engine/slice_buffer.cc +0 -50
  969. data/src/core/lib/event_engine/socket_notifier.h +0 -55
  970. data/src/core/lib/event_engine/thread_pool.cc +0 -195
  971. data/src/core/lib/event_engine/thread_pool.h +0 -114
  972. data/src/core/lib/event_engine/time_util.cc +0 -30
  973. data/src/core/lib/event_engine/time_util.h +0 -32
  974. data/src/core/lib/event_engine/trace.cc +0 -18
  975. data/src/core/lib/event_engine/trace.h +0 -30
  976. data/src/core/lib/event_engine/utils.cc +0 -44
  977. data/src/core/lib/event_engine/utils.h +0 -36
  978. data/src/core/lib/event_engine/windows/iocp.cc +0 -155
  979. data/src/core/lib/event_engine/windows/iocp.h +0 -69
  980. data/src/core/lib/event_engine/windows/win_socket.cc +0 -196
  981. data/src/core/lib/event_engine/windows/win_socket.h +0 -120
  982. data/src/core/lib/event_engine/windows/windows_engine.cc +0 -159
  983. data/src/core/lib/event_engine/windows/windows_engine.h +0 -120
  984. data/src/core/lib/experiments/config.cc +0 -146
  985. data/src/core/lib/experiments/config.h +0 -43
  986. data/src/core/lib/experiments/experiments.cc +0 -75
  987. data/src/core/lib/experiments/experiments.h +0 -56
  988. data/src/core/lib/gpr/alloc.cc +0 -68
  989. data/src/core/lib/gpr/alloc.h +0 -28
  990. data/src/core/lib/gpr/atm.cc +0 -35
  991. data/src/core/lib/gpr/cpu_iphone.cc +0 -44
  992. data/src/core/lib/gpr/cpu_linux.cc +0 -82
  993. data/src/core/lib/gpr/cpu_posix.cc +0 -83
  994. data/src/core/lib/gpr/cpu_windows.cc +0 -33
  995. data/src/core/lib/gpr/log.cc +0 -145
  996. data/src/core/lib/gpr/log_android.cc +0 -77
  997. data/src/core/lib/gpr/log_linux.cc +0 -114
  998. data/src/core/lib/gpr/log_posix.cc +0 -110
  999. data/src/core/lib/gpr/log_windows.cc +0 -115
  1000. data/src/core/lib/gpr/murmur_hash.cc +0 -82
  1001. data/src/core/lib/gpr/murmur_hash.h +0 -29
  1002. data/src/core/lib/gpr/spinlock.h +0 -53
  1003. data/src/core/lib/gpr/string.cc +0 -343
  1004. data/src/core/lib/gpr/string.h +0 -112
  1005. data/src/core/lib/gpr/string_posix.cc +0 -72
  1006. data/src/core/lib/gpr/string_util_windows.cc +0 -55
  1007. data/src/core/lib/gpr/string_windows.cc +0 -69
  1008. data/src/core/lib/gpr/sync.cc +0 -124
  1009. data/src/core/lib/gpr/sync_abseil.cc +0 -100
  1010. data/src/core/lib/gpr/sync_posix.cc +0 -157
  1011. data/src/core/lib/gpr/sync_windows.cc +0 -120
  1012. data/src/core/lib/gpr/time.cc +0 -267
  1013. data/src/core/lib/gpr/time_posix.cc +0 -177
  1014. data/src/core/lib/gpr/time_precise.cc +0 -168
  1015. data/src/core/lib/gpr/time_precise.h +0 -70
  1016. data/src/core/lib/gpr/time_windows.cc +0 -102
  1017. data/src/core/lib/gpr/tls.h +0 -156
  1018. data/src/core/lib/gpr/tmpfile.h +0 -32
  1019. data/src/core/lib/gpr/tmpfile_msys.cc +0 -58
  1020. data/src/core/lib/gpr/tmpfile_posix.cc +0 -69
  1021. data/src/core/lib/gpr/tmpfile_windows.cc +0 -67
  1022. data/src/core/lib/gpr/useful.h +0 -171
  1023. data/src/core/lib/gpr/wrap_memcpy.cc +0 -43
  1024. data/src/core/lib/gprpp/atomic_utils.h +0 -47
  1025. data/src/core/lib/gprpp/bitset.h +0 -201
  1026. data/src/core/lib/gprpp/chunked_vector.h +0 -257
  1027. data/src/core/lib/gprpp/construct_destruct.h +0 -40
  1028. data/src/core/lib/gprpp/cpp_impl_of.h +0 -49
  1029. data/src/core/lib/gprpp/debug_location.h +0 -87
  1030. data/src/core/lib/gprpp/dual_ref_counted.h +0 -327
  1031. data/src/core/lib/gprpp/env.h +0 -53
  1032. data/src/core/lib/gprpp/env_linux.cc +0 -80
  1033. data/src/core/lib/gprpp/env_posix.cc +0 -47
  1034. data/src/core/lib/gprpp/env_windows.cc +0 -56
  1035. data/src/core/lib/gprpp/examine_stack.cc +0 -43
  1036. data/src/core/lib/gprpp/examine_stack.h +0 -45
  1037. data/src/core/lib/gprpp/fork.cc +0 -233
  1038. data/src/core/lib/gprpp/fork.h +0 -95
  1039. data/src/core/lib/gprpp/global_config.h +0 -93
  1040. data/src/core/lib/gprpp/global_config_custom.h +0 -29
  1041. data/src/core/lib/gprpp/global_config_env.cc +0 -139
  1042. data/src/core/lib/gprpp/global_config_env.h +0 -133
  1043. data/src/core/lib/gprpp/global_config_generic.h +0 -40
  1044. data/src/core/lib/gprpp/host_port.cc +0 -114
  1045. data/src/core/lib/gprpp/host_port.h +0 -56
  1046. data/src/core/lib/gprpp/manual_constructor.h +0 -146
  1047. data/src/core/lib/gprpp/match.h +0 -75
  1048. data/src/core/lib/gprpp/memory.h +0 -53
  1049. data/src/core/lib/gprpp/mpscq.cc +0 -108
  1050. data/src/core/lib/gprpp/mpscq.h +0 -99
  1051. data/src/core/lib/gprpp/no_destruct.h +0 -94
  1052. data/src/core/lib/gprpp/notification.h +0 -67
  1053. data/src/core/lib/gprpp/orphanable.h +0 -122
  1054. data/src/core/lib/gprpp/overload.h +0 -59
  1055. data/src/core/lib/gprpp/packed_table.h +0 -40
  1056. data/src/core/lib/gprpp/ref_counted.h +0 -349
  1057. data/src/core/lib/gprpp/ref_counted_ptr.h +0 -337
  1058. data/src/core/lib/gprpp/single_set_ptr.h +0 -87
  1059. data/src/core/lib/gprpp/sorted_pack.h +0 -98
  1060. data/src/core/lib/gprpp/stat.h +0 -36
  1061. data/src/core/lib/gprpp/stat_posix.cc +0 -54
  1062. data/src/core/lib/gprpp/stat_windows.cc +0 -48
  1063. data/src/core/lib/gprpp/status_helper.cc +0 -454
  1064. data/src/core/lib/gprpp/status_helper.h +0 -191
  1065. data/src/core/lib/gprpp/sync.h +0 -200
  1066. data/src/core/lib/gprpp/table.h +0 -451
  1067. data/src/core/lib/gprpp/tchar.cc +0 -49
  1068. data/src/core/lib/gprpp/tchar.h +0 -33
  1069. data/src/core/lib/gprpp/thd.h +0 -171
  1070. data/src/core/lib/gprpp/thd_posix.cc +0 -211
  1071. data/src/core/lib/gprpp/thd_windows.cc +0 -173
  1072. data/src/core/lib/gprpp/time.cc +0 -235
  1073. data/src/core/lib/gprpp/time.h +0 -356
  1074. data/src/core/lib/gprpp/time_averaged_stats.cc +0 -60
  1075. data/src/core/lib/gprpp/time_averaged_stats.h +0 -79
  1076. data/src/core/lib/gprpp/time_util.cc +0 -81
  1077. data/src/core/lib/gprpp/time_util.h +0 -42
  1078. data/src/core/lib/gprpp/unique_type_name.h +0 -104
  1079. data/src/core/lib/gprpp/validation_errors.cc +0 -61
  1080. data/src/core/lib/gprpp/validation_errors.h +0 -110
  1081. data/src/core/lib/gprpp/work_serializer.cc +0 -247
  1082. data/src/core/lib/gprpp/work_serializer.h +0 -86
  1083. data/src/core/lib/handshaker/proxy_mapper.h +0 -53
  1084. data/src/core/lib/handshaker/proxy_mapper_registry.cc +0 -71
  1085. data/src/core/lib/handshaker/proxy_mapper_registry.h +0 -75
  1086. data/src/core/lib/http/format_request.cc +0 -137
  1087. data/src/core/lib/http/format_request.h +0 -38
  1088. data/src/core/lib/http/httpcli.cc +0 -397
  1089. data/src/core/lib/http/httpcli.h +0 -271
  1090. data/src/core/lib/http/httpcli_security_connector.cc +0 -215
  1091. data/src/core/lib/http/httpcli_ssl_credentials.h +0 -39
  1092. data/src/core/lib/http/parser.cc +0 -462
  1093. data/src/core/lib/http/parser.h +0 -130
  1094. data/src/core/lib/iomgr/block_annotate.h +0 -57
  1095. data/src/core/lib/iomgr/buffer_list.cc +0 -307
  1096. data/src/core/lib/iomgr/buffer_list.h +0 -163
  1097. data/src/core/lib/iomgr/call_combiner.cc +0 -257
  1098. data/src/core/lib/iomgr/call_combiner.h +0 -215
  1099. data/src/core/lib/iomgr/cfstream_handle.cc +0 -210
  1100. data/src/core/lib/iomgr/cfstream_handle.h +0 -90
  1101. data/src/core/lib/iomgr/closure.h +0 -266
  1102. data/src/core/lib/iomgr/combiner.cc +0 -330
  1103. data/src/core/lib/iomgr/combiner.h +0 -89
  1104. data/src/core/lib/iomgr/dualstack_socket_posix.cc +0 -48
  1105. data/src/core/lib/iomgr/dynamic_annotations.h +0 -67
  1106. data/src/core/lib/iomgr/endpoint.cc +0 -67
  1107. data/src/core/lib/iomgr/endpoint.h +0 -109
  1108. data/src/core/lib/iomgr/endpoint_cfstream.cc +0 -375
  1109. data/src/core/lib/iomgr/endpoint_cfstream.h +0 -49
  1110. data/src/core/lib/iomgr/endpoint_pair.h +0 -34
  1111. data/src/core/lib/iomgr/endpoint_pair_posix.cc +0 -81
  1112. data/src/core/lib/iomgr/endpoint_pair_windows.cc +0 -86
  1113. data/src/core/lib/iomgr/error.cc +0 -217
  1114. data/src/core/lib/iomgr/error.h +0 -299
  1115. data/src/core/lib/iomgr/error_cfstream.cc +0 -54
  1116. data/src/core/lib/iomgr/error_cfstream.h +0 -31
  1117. data/src/core/lib/iomgr/ev_apple.cc +0 -360
  1118. data/src/core/lib/iomgr/ev_apple.h +0 -43
  1119. data/src/core/lib/iomgr/ev_epoll1_linux.cc +0 -1367
  1120. data/src/core/lib/iomgr/ev_epoll1_linux.h +0 -31
  1121. data/src/core/lib/iomgr/ev_poll_posix.cc +0 -1448
  1122. data/src/core/lib/iomgr/ev_poll_posix.h +0 -29
  1123. data/src/core/lib/iomgr/ev_posix.cc +0 -375
  1124. data/src/core/lib/iomgr/ev_posix.h +0 -209
  1125. data/src/core/lib/iomgr/ev_windows.cc +0 -30
  1126. data/src/core/lib/iomgr/exec_ctx.cc +0 -133
  1127. data/src/core/lib/iomgr/exec_ctx.h +0 -334
  1128. data/src/core/lib/iomgr/executor.cc +0 -451
  1129. data/src/core/lib/iomgr/executor.h +0 -119
  1130. data/src/core/lib/iomgr/fork_posix.cc +0 -120
  1131. data/src/core/lib/iomgr/fork_windows.cc +0 -41
  1132. data/src/core/lib/iomgr/gethostname.h +0 -26
  1133. data/src/core/lib/iomgr/gethostname_fallback.cc +0 -30
  1134. data/src/core/lib/iomgr/gethostname_host_name_max.cc +0 -40
  1135. data/src/core/lib/iomgr/gethostname_sysconf.cc +0 -40
  1136. data/src/core/lib/iomgr/grpc_if_nametoindex.h +0 -30
  1137. data/src/core/lib/iomgr/grpc_if_nametoindex_posix.cc +0 -42
  1138. data/src/core/lib/iomgr/grpc_if_nametoindex_unsupported.cc +0 -38
  1139. data/src/core/lib/iomgr/internal_errqueue.cc +0 -59
  1140. data/src/core/lib/iomgr/internal_errqueue.h +0 -186
  1141. data/src/core/lib/iomgr/iocp_windows.cc +0 -157
  1142. data/src/core/lib/iomgr/iocp_windows.h +0 -48
  1143. data/src/core/lib/iomgr/iomgr.cc +0 -200
  1144. data/src/core/lib/iomgr/iomgr.h +0 -60
  1145. data/src/core/lib/iomgr/iomgr_fwd.h +0 -26
  1146. data/src/core/lib/iomgr/iomgr_internal.cc +0 -53
  1147. data/src/core/lib/iomgr/iomgr_internal.h +0 -74
  1148. data/src/core/lib/iomgr/iomgr_posix.cc +0 -91
  1149. data/src/core/lib/iomgr/iomgr_posix_cfstream.cc +0 -201
  1150. data/src/core/lib/iomgr/iomgr_windows.cc +0 -105
  1151. data/src/core/lib/iomgr/load_file.cc +0 -81
  1152. data/src/core/lib/iomgr/load_file.h +0 -35
  1153. data/src/core/lib/iomgr/lockfree_event.cc +0 -261
  1154. data/src/core/lib/iomgr/lockfree_event.h +0 -72
  1155. data/src/core/lib/iomgr/nameser.h +0 -106
  1156. data/src/core/lib/iomgr/polling_entity.cc +0 -96
  1157. data/src/core/lib/iomgr/polling_entity.h +0 -74
  1158. data/src/core/lib/iomgr/pollset.cc +0 -56
  1159. data/src/core/lib/iomgr/pollset.h +0 -99
  1160. data/src/core/lib/iomgr/pollset_set.cc +0 -55
  1161. data/src/core/lib/iomgr/pollset_set.h +0 -53
  1162. data/src/core/lib/iomgr/pollset_set_windows.cc +0 -52
  1163. data/src/core/lib/iomgr/pollset_set_windows.h +0 -26
  1164. data/src/core/lib/iomgr/pollset_windows.cc +0 -243
  1165. data/src/core/lib/iomgr/pollset_windows.h +0 -70
  1166. data/src/core/lib/iomgr/port.h +0 -238
  1167. data/src/core/lib/iomgr/python_util.h +0 -47
  1168. data/src/core/lib/iomgr/resolve_address.cc +0 -44
  1169. data/src/core/lib/iomgr/resolve_address.h +0 -117
  1170. data/src/core/lib/iomgr/resolve_address_impl.h +0 -59
  1171. data/src/core/lib/iomgr/resolve_address_posix.cc +0 -215
  1172. data/src/core/lib/iomgr/resolve_address_posix.h +0 -64
  1173. data/src/core/lib/iomgr/resolve_address_windows.cc +0 -199
  1174. data/src/core/lib/iomgr/resolve_address_windows.h +0 -64
  1175. data/src/core/lib/iomgr/resolved_address.h +0 -39
  1176. data/src/core/lib/iomgr/sockaddr.h +0 -32
  1177. data/src/core/lib/iomgr/sockaddr_posix.h +0 -57
  1178. data/src/core/lib/iomgr/sockaddr_utils_posix.cc +0 -63
  1179. data/src/core/lib/iomgr/sockaddr_windows.h +0 -57
  1180. data/src/core/lib/iomgr/socket_factory_posix.cc +0 -95
  1181. data/src/core/lib/iomgr/socket_factory_posix.h +0 -69
  1182. data/src/core/lib/iomgr/socket_mutator.cc +0 -97
  1183. data/src/core/lib/iomgr/socket_mutator.h +0 -84
  1184. data/src/core/lib/iomgr/socket_utils.h +0 -47
  1185. data/src/core/lib/iomgr/socket_utils_common_posix.cc +0 -477
  1186. data/src/core/lib/iomgr/socket_utils_linux.cc +0 -42
  1187. data/src/core/lib/iomgr/socket_utils_posix.cc +0 -140
  1188. data/src/core/lib/iomgr/socket_utils_posix.h +0 -255
  1189. data/src/core/lib/iomgr/socket_utils_windows.cc +0 -47
  1190. data/src/core/lib/iomgr/socket_windows.cc +0 -202
  1191. data/src/core/lib/iomgr/socket_windows.h +0 -125
  1192. data/src/core/lib/iomgr/tcp_client.cc +0 -40
  1193. data/src/core/lib/iomgr/tcp_client.h +0 -66
  1194. data/src/core/lib/iomgr/tcp_client_cfstream.cc +0 -211
  1195. data/src/core/lib/iomgr/tcp_client_posix.cc +0 -473
  1196. data/src/core/lib/iomgr/tcp_client_posix.h +0 -72
  1197. data/src/core/lib/iomgr/tcp_client_windows.cc +0 -243
  1198. data/src/core/lib/iomgr/tcp_posix.cc +0 -2075
  1199. data/src/core/lib/iomgr/tcp_posix.h +0 -67
  1200. data/src/core/lib/iomgr/tcp_server.cc +0 -78
  1201. data/src/core/lib/iomgr/tcp_server.h +0 -150
  1202. data/src/core/lib/iomgr/tcp_server_posix.cc +0 -653
  1203. data/src/core/lib/iomgr/tcp_server_utils_posix.h +0 -129
  1204. data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +0 -227
  1205. data/src/core/lib/iomgr/tcp_server_utils_posix_ifaddrs.cc +0 -179
  1206. data/src/core/lib/iomgr/tcp_server_utils_posix_noifaddrs.cc +0 -36
  1207. data/src/core/lib/iomgr/tcp_server_windows.cc +0 -568
  1208. data/src/core/lib/iomgr/tcp_windows.cc +0 -534
  1209. data/src/core/lib/iomgr/tcp_windows.h +0 -52
  1210. data/src/core/lib/iomgr/timer.cc +0 -46
  1211. data/src/core/lib/iomgr/timer.h +0 -136
  1212. data/src/core/lib/iomgr/timer_generic.cc +0 -735
  1213. data/src/core/lib/iomgr/timer_generic.h +0 -40
  1214. data/src/core/lib/iomgr/timer_heap.cc +0 -134
  1215. data/src/core/lib/iomgr/timer_heap.h +0 -43
  1216. data/src/core/lib/iomgr/timer_manager.cc +0 -363
  1217. data/src/core/lib/iomgr/timer_manager.h +0 -41
  1218. data/src/core/lib/iomgr/unix_sockets_posix.cc +0 -96
  1219. data/src/core/lib/iomgr/unix_sockets_posix.h +0 -46
  1220. data/src/core/lib/iomgr/unix_sockets_posix_noop.cc +0 -53
  1221. data/src/core/lib/iomgr/wakeup_fd_eventfd.cc +0 -80
  1222. data/src/core/lib/iomgr/wakeup_fd_nospecial.cc +0 -39
  1223. data/src/core/lib/iomgr/wakeup_fd_pipe.cc +0 -99
  1224. data/src/core/lib/iomgr/wakeup_fd_pipe.h +0 -28
  1225. data/src/core/lib/iomgr/wakeup_fd_posix.cc +0 -73
  1226. data/src/core/lib/iomgr/wakeup_fd_posix.h +0 -96
  1227. data/src/core/lib/json/json.h +0 -246
  1228. data/src/core/lib/json/json_args.h +0 -34
  1229. data/src/core/lib/json/json_object_loader.cc +0 -202
  1230. data/src/core/lib/json/json_object_loader.h +0 -598
  1231. data/src/core/lib/json/json_reader.cc +0 -929
  1232. data/src/core/lib/json/json_util.cc +0 -106
  1233. data/src/core/lib/json/json_util.h +0 -163
  1234. data/src/core/lib/json/json_writer.cc +0 -340
  1235. data/src/core/lib/load_balancing/lb_policy.cc +0 -93
  1236. data/src/core/lib/load_balancing/lb_policy.h +0 -435
  1237. data/src/core/lib/load_balancing/lb_policy_factory.h +0 -49
  1238. data/src/core/lib/load_balancing/lb_policy_registry.cc +0 -141
  1239. data/src/core/lib/load_balancing/lb_policy_registry.h +0 -82
  1240. data/src/core/lib/load_balancing/subchannel_interface.h +0 -140
  1241. data/src/core/lib/matchers/matchers.cc +0 -330
  1242. data/src/core/lib/matchers/matchers.h +0 -162
  1243. data/src/core/lib/promise/activity.cc +0 -120
  1244. data/src/core/lib/promise/activity.h +0 -581
  1245. data/src/core/lib/promise/arena_promise.h +0 -201
  1246. data/src/core/lib/promise/call_push_pull.h +0 -148
  1247. data/src/core/lib/promise/context.h +0 -85
  1248. data/src/core/lib/promise/detail/basic_seq.h +0 -516
  1249. data/src/core/lib/promise/detail/promise_factory.h +0 -187
  1250. data/src/core/lib/promise/detail/promise_like.h +0 -85
  1251. data/src/core/lib/promise/detail/status.h +0 -50
  1252. data/src/core/lib/promise/exec_ctx_wakeup_scheduler.h +0 -48
  1253. data/src/core/lib/promise/intra_activity_waiter.h +0 -49
  1254. data/src/core/lib/promise/latch.h +0 -103
  1255. data/src/core/lib/promise/loop.h +0 -136
  1256. data/src/core/lib/promise/map.h +0 -87
  1257. data/src/core/lib/promise/poll.h +0 -66
  1258. data/src/core/lib/promise/promise.h +0 -96
  1259. data/src/core/lib/promise/race.h +0 -83
  1260. data/src/core/lib/promise/seq.h +0 -108
  1261. data/src/core/lib/promise/sleep.cc +0 -89
  1262. data/src/core/lib/promise/sleep.h +0 -85
  1263. data/src/core/lib/promise/try_seq.h +0 -177
  1264. data/src/core/lib/resolver/resolver.cc +0 -37
  1265. data/src/core/lib/resolver/resolver.h +0 -138
  1266. data/src/core/lib/resolver/resolver_factory.h +0 -77
  1267. data/src/core/lib/resolver/resolver_registry.cc +0 -149
  1268. data/src/core/lib/resolver/resolver_registry.h +0 -123
  1269. data/src/core/lib/resolver/server_address.cc +0 -180
  1270. data/src/core/lib/resolver/server_address.h +0 -147
  1271. data/src/core/lib/resource_quota/api.cc +0 -105
  1272. data/src/core/lib/resource_quota/api.h +0 -49
  1273. data/src/core/lib/resource_quota/arena.cc +0 -119
  1274. data/src/core/lib/resource_quota/arena.h +0 -163
  1275. data/src/core/lib/resource_quota/memory_quota.cc +0 -602
  1276. data/src/core/lib/resource_quota/memory_quota.h +0 -530
  1277. data/src/core/lib/resource_quota/periodic_update.cc +0 -78
  1278. data/src/core/lib/resource_quota/periodic_update.h +0 -71
  1279. data/src/core/lib/resource_quota/resource_quota.cc +0 -33
  1280. data/src/core/lib/resource_quota/resource_quota.h +0 -74
  1281. data/src/core/lib/resource_quota/thread_quota.cc +0 -45
  1282. data/src/core/lib/resource_quota/thread_quota.h +0 -61
  1283. data/src/core/lib/resource_quota/trace.cc +0 -19
  1284. data/src/core/lib/resource_quota/trace.h +0 -24
  1285. data/src/core/lib/security/authorization/authorization_engine.h +0 -44
  1286. data/src/core/lib/security/authorization/authorization_policy_provider.h +0 -47
  1287. data/src/core/lib/security/authorization/authorization_policy_provider_vtable.cc +0 -50
  1288. data/src/core/lib/security/authorization/evaluate_args.cc +0 -221
  1289. data/src/core/lib/security/authorization/evaluate_args.h +0 -95
  1290. data/src/core/lib/security/authorization/grpc_authorization_engine.cc +0 -66
  1291. data/src/core/lib/security/authorization/grpc_authorization_engine.h +0 -69
  1292. data/src/core/lib/security/authorization/grpc_server_authz_filter.cc +0 -120
  1293. data/src/core/lib/security/authorization/grpc_server_authz_filter.h +0 -61
  1294. data/src/core/lib/security/authorization/matchers.cc +0 -238
  1295. data/src/core/lib/security/authorization/matchers.h +0 -218
  1296. data/src/core/lib/security/authorization/rbac_policy.cc +0 -446
  1297. data/src/core/lib/security/authorization/rbac_policy.h +0 -178
  1298. data/src/core/lib/security/certificate_provider/certificate_provider_factory.h +0 -66
  1299. data/src/core/lib/security/certificate_provider/certificate_provider_registry.cc +0 -60
  1300. data/src/core/lib/security/certificate_provider/certificate_provider_registry.h +0 -70
  1301. data/src/core/lib/security/context/security_context.cc +0 -330
  1302. data/src/core/lib/security/context/security_context.h +0 -171
  1303. data/src/core/lib/security/credentials/alts/alts_credentials.cc +0 -119
  1304. data/src/core/lib/security/credentials/alts/alts_credentials.h +0 -123
  1305. data/src/core/lib/security/credentials/alts/check_gcp_environment.cc +0 -72
  1306. data/src/core/lib/security/credentials/alts/check_gcp_environment.h +0 -57
  1307. data/src/core/lib/security/credentials/alts/check_gcp_environment_linux.cc +0 -68
  1308. data/src/core/lib/security/credentials/alts/check_gcp_environment_no_op.cc +0 -33
  1309. data/src/core/lib/security/credentials/alts/check_gcp_environment_windows.cc +0 -102
  1310. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_client_options.cc +0 -125
  1311. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_options.cc +0 -46
  1312. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_options.h +0 -75
  1313. data/src/core/lib/security/credentials/alts/grpc_alts_credentials_server_options.cc +0 -56
  1314. data/src/core/lib/security/credentials/call_creds_util.cc +0 -97
  1315. data/src/core/lib/security/credentials/call_creds_util.h +0 -43
  1316. data/src/core/lib/security/credentials/channel_creds_registry.h +0 -103
  1317. data/src/core/lib/security/credentials/channel_creds_registry_init.cc +0 -81
  1318. data/src/core/lib/security/credentials/composite/composite_credentials.cc +0 -171
  1319. data/src/core/lib/security/credentials/composite/composite_credentials.h +0 -132
  1320. data/src/core/lib/security/credentials/credentials.cc +0 -159
  1321. data/src/core/lib/security/credentials/credentials.h +0 -298
  1322. data/src/core/lib/security/credentials/external/aws_external_account_credentials.cc +0 -524
  1323. data/src/core/lib/security/credentials/external/aws_external_account_credentials.h +0 -100
  1324. data/src/core/lib/security/credentials/external/aws_request_signer.cc +0 -223
  1325. data/src/core/lib/security/credentials/external/aws_request_signer.h +0 -72
  1326. data/src/core/lib/security/credentials/external/external_account_credentials.cc +0 -572
  1327. data/src/core/lib/security/credentials/external/external_account_credentials.h +0 -129
  1328. data/src/core/lib/security/credentials/external/file_external_account_credentials.cc +0 -142
  1329. data/src/core/lib/security/credentials/external/file_external_account_credentials.h +0 -55
  1330. data/src/core/lib/security/credentials/external/url_external_account_credentials.cc +0 -246
  1331. data/src/core/lib/security/credentials/external/url_external_account_credentials.h +0 -71
  1332. data/src/core/lib/security/credentials/fake/fake_credentials.cc +0 -112
  1333. data/src/core/lib/security/credentials/fake/fake_credentials.h +0 -96
  1334. data/src/core/lib/security/credentials/google_default/credentials_generic.cc +0 -40
  1335. data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +0 -500
  1336. data/src/core/lib/security/credentials/google_default/google_default_credentials.h +0 -100
  1337. data/src/core/lib/security/credentials/iam/iam_credentials.cc +0 -82
  1338. data/src/core/lib/security/credentials/iam/iam_credentials.h +0 -65
  1339. data/src/core/lib/security/credentials/insecure/insecure_credentials.cc +0 -73
  1340. data/src/core/lib/security/credentials/insecure/insecure_credentials.h +0 -61
  1341. data/src/core/lib/security/credentials/jwt/json_token.cc +0 -298
  1342. data/src/core/lib/security/credentials/jwt/json_token.h +0 -76
  1343. data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +0 -183
  1344. data/src/core/lib/security/credentials/jwt/jwt_credentials.h +0 -107
  1345. data/src/core/lib/security/credentials/jwt/jwt_verifier.cc +0 -957
  1346. data/src/core/lib/security/credentials/jwt/jwt_verifier.h +0 -124
  1347. data/src/core/lib/security/credentials/local/local_credentials.cc +0 -71
  1348. data/src/core/lib/security/credentials/local/local_credentials.h +0 -77
  1349. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +0 -751
  1350. data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +0 -220
  1351. data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +0 -214
  1352. data/src/core/lib/security/credentials/plugin/plugin_credentials.h +0 -125
  1353. data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +0 -381
  1354. data/src/core/lib/security/credentials/ssl/ssl_credentials.h +0 -131
  1355. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.cc +0 -348
  1356. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_distributor.h +0 -223
  1357. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.cc +0 -484
  1358. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_provider.h +0 -206
  1359. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.cc +0 -241
  1360. data/src/core/lib/security/credentials/tls/grpc_tls_certificate_verifier.h +0 -168
  1361. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.cc +0 -122
  1362. data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.h +0 -117
  1363. data/src/core/lib/security/credentials/tls/tls_credentials.cc +0 -150
  1364. data/src/core/lib/security/credentials/tls/tls_credentials.h +0 -71
  1365. data/src/core/lib/security/credentials/tls/tls_utils.cc +0 -127
  1366. data/src/core/lib/security/credentials/tls/tls_utils.h +0 -51
  1367. data/src/core/lib/security/credentials/xds/xds_credentials.cc +0 -236
  1368. data/src/core/lib/security/credentials/xds/xds_credentials.h +0 -114
  1369. data/src/core/lib/security/security_connector/alts/alts_security_connector.cc +0 -317
  1370. data/src/core/lib/security/security_connector/alts/alts_security_connector.h +0 -79
  1371. data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +0 -322
  1372. data/src/core/lib/security/security_connector/fake/fake_security_connector.h +0 -43
  1373. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.cc +0 -120
  1374. data/src/core/lib/security/security_connector/insecure/insecure_security_connector.h +0 -108
  1375. data/src/core/lib/security/security_connector/load_system_roots.h +0 -33
  1376. data/src/core/lib/security/security_connector/load_system_roots_fallback.cc +0 -35
  1377. data/src/core/lib/security/security_connector/load_system_roots_supported.cc +0 -178
  1378. data/src/core/lib/security/security_connector/load_system_roots_supported.h +0 -46
  1379. data/src/core/lib/security/security_connector/local/local_security_connector.cc +0 -310
  1380. data/src/core/lib/security/security_connector/local/local_security_connector.h +0 -63
  1381. data/src/core/lib/security/security_connector/security_connector.cc +0 -127
  1382. data/src/core/lib/security/security_connector/security_connector.h +0 -201
  1383. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +0 -463
  1384. data/src/core/lib/security/security_connector/ssl/ssl_security_connector.h +0 -83
  1385. data/src/core/lib/security/security_connector/ssl_utils.cc +0 -627
  1386. data/src/core/lib/security/security_connector/ssl_utils.h +0 -187
  1387. data/src/core/lib/security/security_connector/ssl_utils_config.cc +0 -32
  1388. data/src/core/lib/security/security_connector/ssl_utils_config.h +0 -30
  1389. data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +0 -834
  1390. data/src/core/lib/security/security_connector/tls/tls_security_connector.h +0 -286
  1391. data/src/core/lib/security/transport/auth_filters.h +0 -76
  1392. data/src/core/lib/security/transport/client_auth_filter.cc +0 -227
  1393. data/src/core/lib/security/transport/secure_endpoint.cc +0 -568
  1394. data/src/core/lib/security/transport/secure_endpoint.h +0 -43
  1395. data/src/core/lib/security/transport/security_handshaker.cc +0 -673
  1396. data/src/core/lib/security/transport/security_handshaker.h +0 -51
  1397. data/src/core/lib/security/transport/server_auth_filter.cc +0 -360
  1398. data/src/core/lib/security/transport/tsi_error.cc +0 -28
  1399. data/src/core/lib/security/transport/tsi_error.h +0 -30
  1400. data/src/core/lib/security/util/json_util.cc +0 -71
  1401. data/src/core/lib/security/util/json_util.h +0 -43
  1402. data/src/core/lib/service_config/service_config.h +0 -89
  1403. data/src/core/lib/service_config/service_config_call_data.h +0 -76
  1404. data/src/core/lib/service_config/service_config_impl.cc +0 -238
  1405. data/src/core/lib/service_config/service_config_impl.h +0 -128
  1406. data/src/core/lib/service_config/service_config_parser.cc +0 -98
  1407. data/src/core/lib/service_config/service_config_parser.h +0 -101
  1408. data/src/core/lib/slice/b64.cc +0 -239
  1409. data/src/core/lib/slice/b64.h +0 -52
  1410. data/src/core/lib/slice/percent_encoding.cc +0 -150
  1411. data/src/core/lib/slice/percent_encoding.h +0 -54
  1412. data/src/core/lib/slice/slice.cc +0 -496
  1413. data/src/core/lib/slice/slice.h +0 -389
  1414. data/src/core/lib/slice/slice_api.cc +0 -39
  1415. data/src/core/lib/slice/slice_buffer.cc +0 -473
  1416. data/src/core/lib/slice/slice_buffer.h +0 -137
  1417. data/src/core/lib/slice/slice_buffer_api.cc +0 -35
  1418. data/src/core/lib/slice/slice_internal.h +0 -105
  1419. data/src/core/lib/slice/slice_refcount.cc +0 -35
  1420. data/src/core/lib/slice/slice_refcount.h +0 -45
  1421. data/src/core/lib/slice/slice_refcount_base.h +0 -60
  1422. data/src/core/lib/slice/slice_string_helpers.cc +0 -28
  1423. data/src/core/lib/slice/slice_string_helpers.h +0 -31
  1424. data/src/core/lib/surface/api_trace.cc +0 -25
  1425. data/src/core/lib/surface/api_trace.h +0 -53
  1426. data/src/core/lib/surface/builtins.cc +0 -54
  1427. data/src/core/lib/surface/builtins.h +0 -26
  1428. data/src/core/lib/surface/byte_buffer.cc +0 -98
  1429. data/src/core/lib/surface/byte_buffer_reader.cc +0 -101
  1430. data/src/core/lib/surface/call.cc +0 -1916
  1431. data/src/core/lib/surface/call.h +0 -135
  1432. data/src/core/lib/surface/call_details.cc +0 -41
  1433. data/src/core/lib/surface/call_log_batch.cc +0 -117
  1434. data/src/core/lib/surface/call_test_only.h +0 -46
  1435. data/src/core/lib/surface/channel.cc +0 -442
  1436. data/src/core/lib/surface/channel.h +0 -206
  1437. data/src/core/lib/surface/channel_init.cc +0 -55
  1438. data/src/core/lib/surface/channel_init.h +0 -84
  1439. data/src/core/lib/surface/channel_ping.cc +0 -69
  1440. data/src/core/lib/surface/channel_stack_type.cc +0 -57
  1441. data/src/core/lib/surface/channel_stack_type.h +0 -45
  1442. data/src/core/lib/surface/completion_queue.cc +0 -1425
  1443. data/src/core/lib/surface/completion_queue.h +0 -100
  1444. data/src/core/lib/surface/completion_queue_factory.cc +0 -94
  1445. data/src/core/lib/surface/completion_queue_factory.h +0 -37
  1446. data/src/core/lib/surface/event_string.cc +0 -56
  1447. data/src/core/lib/surface/event_string.h +0 -31
  1448. data/src/core/lib/surface/init.cc +0 -260
  1449. data/src/core/lib/surface/init.h +0 -25
  1450. data/src/core/lib/surface/init_internally.cc +0 -24
  1451. data/src/core/lib/surface/init_internally.h +0 -28
  1452. data/src/core/lib/surface/lame_client.cc +0 -152
  1453. data/src/core/lib/surface/lame_client.h +0 -71
  1454. data/src/core/lib/surface/metadata_array.cc +0 -38
  1455. data/src/core/lib/surface/server.cc +0 -1577
  1456. data/src/core/lib/surface/server.h +0 -526
  1457. data/src/core/lib/surface/validate_metadata.cc +0 -123
  1458. data/src/core/lib/surface/validate_metadata.h +0 -48
  1459. data/src/core/lib/surface/version.cc +0 -28
  1460. data/src/core/lib/transport/bdp_estimator.cc +0 -86
  1461. data/src/core/lib/transport/bdp_estimator.h +0 -94
  1462. data/src/core/lib/transport/connectivity_state.cc +0 -189
  1463. data/src/core/lib/transport/connectivity_state.h +0 -144
  1464. data/src/core/lib/transport/error_utils.cc +0 -165
  1465. data/src/core/lib/transport/error_utils.h +0 -63
  1466. data/src/core/lib/transport/handshaker.cc +0 -225
  1467. data/src/core/lib/transport/handshaker.h +0 -167
  1468. data/src/core/lib/transport/handshaker_factory.h +0 -48
  1469. data/src/core/lib/transport/handshaker_registry.cc +0 -55
  1470. data/src/core/lib/transport/handshaker_registry.h +0 -70
  1471. data/src/core/lib/transport/http2_errors.h +0 -41
  1472. data/src/core/lib/transport/http_connect_handshaker.cc +0 -401
  1473. data/src/core/lib/transport/http_connect_handshaker.h +0 -42
  1474. data/src/core/lib/transport/metadata_batch.cc +0 -291
  1475. data/src/core/lib/transport/metadata_batch.h +0 -1310
  1476. data/src/core/lib/transport/parsed_metadata.cc +0 -39
  1477. data/src/core/lib/transport/parsed_metadata.h +0 -409
  1478. data/src/core/lib/transport/pid_controller.cc +0 -51
  1479. data/src/core/lib/transport/pid_controller.h +0 -116
  1480. data/src/core/lib/transport/status_conversion.cc +0 -92
  1481. data/src/core/lib/transport/status_conversion.h +0 -38
  1482. data/src/core/lib/transport/tcp_connect_handshaker.cc +0 -251
  1483. data/src/core/lib/transport/tcp_connect_handshaker.h +0 -39
  1484. data/src/core/lib/transport/timeout_encoding.cc +0 -284
  1485. data/src/core/lib/transport/timeout_encoding.h +0 -72
  1486. data/src/core/lib/transport/transport.cc +0 -239
  1487. data/src/core/lib/transport/transport.h +0 -594
  1488. data/src/core/lib/transport/transport_fwd.h +0 -20
  1489. data/src/core/lib/transport/transport_impl.h +0 -95
  1490. data/src/core/lib/transport/transport_op_string.cc +0 -146
  1491. data/src/core/lib/uri/uri_parser.cc +0 -373
  1492. data/src/core/lib/uri/uri_parser.h +0 -101
  1493. data/src/core/plugin_registry/grpc_plugin_registry.cc +0 -117
  1494. data/src/core/plugin_registry/grpc_plugin_registry_extra.cc +0 -73
  1495. data/src/core/tsi/alts/crypt/aes_gcm.cc +0 -690
  1496. data/src/core/tsi/alts/crypt/gsec.cc +0 -190
  1497. data/src/core/tsi/alts/crypt/gsec.h +0 -459
  1498. data/src/core/tsi/alts/frame_protector/alts_counter.cc +0 -118
  1499. data/src/core/tsi/alts/frame_protector/alts_counter.h +0 -98
  1500. data/src/core/tsi/alts/frame_protector/alts_crypter.cc +0 -66
  1501. data/src/core/tsi/alts/frame_protector/alts_crypter.h +0 -255
  1502. data/src/core/tsi/alts/frame_protector/alts_frame_protector.cc +0 -408
  1503. data/src/core/tsi/alts/frame_protector/alts_frame_protector.h +0 -55
  1504. data/src/core/tsi/alts/frame_protector/alts_record_protocol_crypter_common.cc +0 -114
  1505. data/src/core/tsi/alts/frame_protector/alts_record_protocol_crypter_common.h +0 -114
  1506. data/src/core/tsi/alts/frame_protector/alts_seal_privacy_integrity_crypter.cc +0 -105
  1507. data/src/core/tsi/alts/frame_protector/alts_unseal_privacy_integrity_crypter.cc +0 -103
  1508. data/src/core/tsi/alts/frame_protector/frame_handler.cc +0 -219
  1509. data/src/core/tsi/alts/frame_protector/frame_handler.h +0 -236
  1510. data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +0 -927
  1511. data/src/core/tsi/alts/handshaker/alts_handshaker_client.h +0 -160
  1512. data/src/core/tsi/alts/handshaker/alts_shared_resource.cc +0 -91
  1513. data/src/core/tsi/alts/handshaker/alts_shared_resource.h +0 -73
  1514. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +0 -720
  1515. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.h +0 -104
  1516. data/src/core/tsi/alts/handshaker/alts_tsi_handshaker_private.h +0 -89
  1517. data/src/core/tsi/alts/handshaker/alts_tsi_utils.cc +0 -64
  1518. data/src/core/tsi/alts/handshaker/alts_tsi_utils.h +0 -53
  1519. data/src/core/tsi/alts/handshaker/transport_security_common_api.cc +0 -223
  1520. data/src/core/tsi/alts/handshaker/transport_security_common_api.h +0 -171
  1521. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_integrity_only_record_protocol.cc +0 -226
  1522. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_integrity_only_record_protocol.h +0 -54
  1523. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_privacy_integrity_record_protocol.cc +0 -144
  1524. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_privacy_integrity_record_protocol.h +0 -49
  1525. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_record_protocol.h +0 -91
  1526. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_record_protocol_common.cc +0 -174
  1527. data/src/core/tsi/alts/zero_copy_frame_protector/alts_grpc_record_protocol_common.h +0 -99
  1528. data/src/core/tsi/alts/zero_copy_frame_protector/alts_iovec_record_protocol.cc +0 -478
  1529. data/src/core/tsi/alts/zero_copy_frame_protector/alts_iovec_record_protocol.h +0 -199
  1530. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.cc +0 -315
  1531. data/src/core/tsi/alts/zero_copy_frame_protector/alts_zero_copy_grpc_protector.h +0 -57
  1532. data/src/core/tsi/fake_transport_security.cc +0 -844
  1533. data/src/core/tsi/fake_transport_security.h +0 -53
  1534. data/src/core/tsi/local_transport_security.cc +0 -174
  1535. data/src/core/tsi/local_transport_security.h +0 -47
  1536. data/src/core/tsi/ssl/key_logging/ssl_key_logging.cc +0 -141
  1537. data/src/core/tsi/ssl/key_logging/ssl_key_logging.h +0 -81
  1538. data/src/core/tsi/ssl/session_cache/ssl_session.h +0 -71
  1539. data/src/core/tsi/ssl/session_cache/ssl_session_boringssl.cc +0 -59
  1540. data/src/core/tsi/ssl/session_cache/ssl_session_cache.cc +0 -179
  1541. data/src/core/tsi/ssl/session_cache/ssl_session_cache.h +0 -99
  1542. data/src/core/tsi/ssl/session_cache/ssl_session_openssl.cc +0 -77
  1543. data/src/core/tsi/ssl_transport_security.cc +0 -2441
  1544. data/src/core/tsi/ssl_transport_security.h +0 -405
  1545. data/src/core/tsi/ssl_types.h +0 -42
  1546. data/src/core/tsi/transport_security.cc +0 -396
  1547. data/src/core/tsi/transport_security.h +0 -143
  1548. data/src/core/tsi/transport_security_grpc.cc +0 -74
  1549. data/src/core/tsi/transport_security_grpc.h +0 -83
  1550. data/src/core/tsi/transport_security_interface.h +0 -521
  1551. data/src/ruby/lib/grpc/2.6/grpc_c.so +0 -0
  1552. data/third_party/abseil-cpp/absl/algorithm/algorithm.h +0 -159
  1553. data/third_party/abseil-cpp/absl/algorithm/container.h +0 -1774
  1554. data/third_party/abseil-cpp/absl/base/attributes.h +0 -762
  1555. data/third_party/abseil-cpp/absl/base/call_once.h +0 -219
  1556. data/third_party/abseil-cpp/absl/base/casts.h +0 -180
  1557. data/third_party/abseil-cpp/absl/base/config.h +0 -913
  1558. data/third_party/abseil-cpp/absl/base/const_init.h +0 -76
  1559. data/third_party/abseil-cpp/absl/base/dynamic_annotations.h +0 -471
  1560. data/third_party/abseil-cpp/absl/base/internal/atomic_hook.h +0 -200
  1561. data/third_party/abseil-cpp/absl/base/internal/cycleclock.cc +0 -77
  1562. data/third_party/abseil-cpp/absl/base/internal/cycleclock.h +0 -159
  1563. data/third_party/abseil-cpp/absl/base/internal/direct_mmap.h +0 -169
  1564. data/third_party/abseil-cpp/absl/base/internal/dynamic_annotations.h +0 -398
  1565. data/third_party/abseil-cpp/absl/base/internal/endian.h +0 -282
  1566. data/third_party/abseil-cpp/absl/base/internal/errno_saver.h +0 -43
  1567. data/third_party/abseil-cpp/absl/base/internal/fast_type_id.h +0 -50
  1568. data/third_party/abseil-cpp/absl/base/internal/hide_ptr.h +0 -51
  1569. data/third_party/abseil-cpp/absl/base/internal/identity.h +0 -37
  1570. data/third_party/abseil-cpp/absl/base/internal/inline_variable.h +0 -107
  1571. data/third_party/abseil-cpp/absl/base/internal/invoke.h +0 -241
  1572. data/third_party/abseil-cpp/absl/base/internal/low_level_alloc.cc +0 -620
  1573. data/third_party/abseil-cpp/absl/base/internal/low_level_alloc.h +0 -126
  1574. data/third_party/abseil-cpp/absl/base/internal/low_level_scheduling.h +0 -134
  1575. data/third_party/abseil-cpp/absl/base/internal/per_thread_tls.h +0 -52
  1576. data/third_party/abseil-cpp/absl/base/internal/prefetch.h +0 -138
  1577. data/third_party/abseil-cpp/absl/base/internal/raw_logging.cc +0 -249
  1578. data/third_party/abseil-cpp/absl/base/internal/raw_logging.h +0 -196
  1579. data/third_party/abseil-cpp/absl/base/internal/scheduling_mode.h +0 -58
  1580. data/third_party/abseil-cpp/absl/base/internal/spinlock.cc +0 -232
  1581. data/third_party/abseil-cpp/absl/base/internal/spinlock.h +0 -256
  1582. data/third_party/abseil-cpp/absl/base/internal/spinlock_akaros.inc +0 -35
  1583. data/third_party/abseil-cpp/absl/base/internal/spinlock_linux.inc +0 -71
  1584. data/third_party/abseil-cpp/absl/base/internal/spinlock_posix.inc +0 -46
  1585. data/third_party/abseil-cpp/absl/base/internal/spinlock_wait.cc +0 -81
  1586. data/third_party/abseil-cpp/absl/base/internal/spinlock_wait.h +0 -95
  1587. data/third_party/abseil-cpp/absl/base/internal/spinlock_win32.inc +0 -37
  1588. data/third_party/abseil-cpp/absl/base/internal/strerror.cc +0 -88
  1589. data/third_party/abseil-cpp/absl/base/internal/strerror.h +0 -39
  1590. data/third_party/abseil-cpp/absl/base/internal/sysinfo.cc +0 -507
  1591. data/third_party/abseil-cpp/absl/base/internal/sysinfo.h +0 -74
  1592. data/third_party/abseil-cpp/absl/base/internal/thread_annotations.h +0 -271
  1593. data/third_party/abseil-cpp/absl/base/internal/thread_identity.cc +0 -156
  1594. data/third_party/abseil-cpp/absl/base/internal/thread_identity.h +0 -265
  1595. data/third_party/abseil-cpp/absl/base/internal/throw_delegate.cc +0 -212
  1596. data/third_party/abseil-cpp/absl/base/internal/throw_delegate.h +0 -75
  1597. data/third_party/abseil-cpp/absl/base/internal/tsan_mutex_interface.h +0 -68
  1598. data/third_party/abseil-cpp/absl/base/internal/unaligned_access.h +0 -82
  1599. data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.cc +0 -153
  1600. data/third_party/abseil-cpp/absl/base/internal/unscaledcycleclock.h +0 -133
  1601. data/third_party/abseil-cpp/absl/base/log_severity.cc +0 -55
  1602. data/third_party/abseil-cpp/absl/base/log_severity.h +0 -172
  1603. data/third_party/abseil-cpp/absl/base/macros.h +0 -158
  1604. data/third_party/abseil-cpp/absl/base/optimization.h +0 -252
  1605. data/third_party/abseil-cpp/absl/base/options.h +0 -238
  1606. data/third_party/abseil-cpp/absl/base/policy_checks.h +0 -111
  1607. data/third_party/abseil-cpp/absl/base/port.h +0 -25
  1608. data/third_party/abseil-cpp/absl/base/thread_annotations.h +0 -335
  1609. data/third_party/abseil-cpp/absl/container/fixed_array.h +0 -529
  1610. data/third_party/abseil-cpp/absl/container/flat_hash_map.h +0 -613
  1611. data/third_party/abseil-cpp/absl/container/flat_hash_set.h +0 -510
  1612. data/third_party/abseil-cpp/absl/container/inlined_vector.h +0 -866
  1613. data/third_party/abseil-cpp/absl/container/internal/common.h +0 -207
  1614. data/third_party/abseil-cpp/absl/container/internal/compressed_tuple.h +0 -290
  1615. data/third_party/abseil-cpp/absl/container/internal/container_memory.h +0 -442
  1616. data/third_party/abseil-cpp/absl/container/internal/hash_function_defaults.h +0 -163
  1617. data/third_party/abseil-cpp/absl/container/internal/hash_policy_traits.h +0 -208
  1618. data/third_party/abseil-cpp/absl/container/internal/hashtable_debug_hooks.h +0 -85
  1619. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.cc +0 -238
  1620. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.h +0 -299
  1621. data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler_force_weak_definition.cc +0 -31
  1622. data/third_party/abseil-cpp/absl/container/internal/inlined_vector.h +0 -953
  1623. data/third_party/abseil-cpp/absl/container/internal/layout.h +0 -743
  1624. data/third_party/abseil-cpp/absl/container/internal/raw_hash_map.h +0 -198
  1625. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.cc +0 -71
  1626. data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.h +0 -2365
  1627. data/third_party/abseil-cpp/absl/debugging/internal/address_is_readable.cc +0 -96
  1628. data/third_party/abseil-cpp/absl/debugging/internal/address_is_readable.h +0 -32
  1629. data/third_party/abseil-cpp/absl/debugging/internal/demangle.cc +0 -1959
  1630. data/third_party/abseil-cpp/absl/debugging/internal/demangle.h +0 -71
  1631. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.cc +0 -387
  1632. data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.h +0 -139
  1633. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_aarch64-inl.inc +0 -204
  1634. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_arm-inl.inc +0 -139
  1635. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_config.h +0 -88
  1636. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_emscripten-inl.inc +0 -110
  1637. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_generic-inl.inc +0 -108
  1638. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_powerpc-inl.inc +0 -258
  1639. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_riscv-inl.inc +0 -236
  1640. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_unimplemented-inl.inc +0 -24
  1641. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_win32-inl.inc +0 -93
  1642. data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_x86-inl.inc +0 -369
  1643. data/third_party/abseil-cpp/absl/debugging/internal/symbolize.h +0 -153
  1644. data/third_party/abseil-cpp/absl/debugging/internal/vdso_support.cc +0 -204
  1645. data/third_party/abseil-cpp/absl/debugging/internal/vdso_support.h +0 -158
  1646. data/third_party/abseil-cpp/absl/debugging/stacktrace.cc +0 -142
  1647. data/third_party/abseil-cpp/absl/debugging/stacktrace.h +0 -231
  1648. data/third_party/abseil-cpp/absl/debugging/symbolize.cc +0 -43
  1649. data/third_party/abseil-cpp/absl/debugging/symbolize.h +0 -99
  1650. data/third_party/abseil-cpp/absl/debugging/symbolize_darwin.inc +0 -101
  1651. data/third_party/abseil-cpp/absl/debugging/symbolize_elf.inc +0 -1613
  1652. data/third_party/abseil-cpp/absl/debugging/symbolize_emscripten.inc +0 -72
  1653. data/third_party/abseil-cpp/absl/debugging/symbolize_unimplemented.inc +0 -40
  1654. data/third_party/abseil-cpp/absl/debugging/symbolize_win32.inc +0 -81
  1655. data/third_party/abseil-cpp/absl/functional/any_invocable.h +0 -313
  1656. data/third_party/abseil-cpp/absl/functional/bind_front.h +0 -193
  1657. data/third_party/abseil-cpp/absl/functional/function_ref.h +0 -143
  1658. data/third_party/abseil-cpp/absl/functional/internal/any_invocable.h +0 -857
  1659. data/third_party/abseil-cpp/absl/functional/internal/front_binder.h +0 -95
  1660. data/third_party/abseil-cpp/absl/functional/internal/function_ref.h +0 -106
  1661. data/third_party/abseil-cpp/absl/hash/hash.h +0 -421
  1662. data/third_party/abseil-cpp/absl/hash/internal/city.cc +0 -349
  1663. data/third_party/abseil-cpp/absl/hash/internal/city.h +0 -78
  1664. data/third_party/abseil-cpp/absl/hash/internal/hash.cc +0 -69
  1665. data/third_party/abseil-cpp/absl/hash/internal/hash.h +0 -1291
  1666. data/third_party/abseil-cpp/absl/hash/internal/low_level_hash.cc +0 -123
  1667. data/third_party/abseil-cpp/absl/hash/internal/low_level_hash.h +0 -50
  1668. data/third_party/abseil-cpp/absl/memory/memory.h +0 -699
  1669. data/third_party/abseil-cpp/absl/meta/type_traits.h +0 -797
  1670. data/third_party/abseil-cpp/absl/numeric/bits.h +0 -178
  1671. data/third_party/abseil-cpp/absl/numeric/int128.cc +0 -385
  1672. data/third_party/abseil-cpp/absl/numeric/int128.h +0 -1165
  1673. data/third_party/abseil-cpp/absl/numeric/int128_have_intrinsic.inc +0 -296
  1674. data/third_party/abseil-cpp/absl/numeric/int128_no_intrinsic.inc +0 -311
  1675. data/third_party/abseil-cpp/absl/numeric/internal/bits.h +0 -358
  1676. data/third_party/abseil-cpp/absl/numeric/internal/representation.h +0 -55
  1677. data/third_party/abseil-cpp/absl/profiling/internal/exponential_biased.cc +0 -93
  1678. data/third_party/abseil-cpp/absl/profiling/internal/exponential_biased.h +0 -130
  1679. data/third_party/abseil-cpp/absl/profiling/internal/sample_recorder.h +0 -245
  1680. data/third_party/abseil-cpp/absl/random/bernoulli_distribution.h +0 -200
  1681. data/third_party/abseil-cpp/absl/random/beta_distribution.h +0 -427
  1682. data/third_party/abseil-cpp/absl/random/discrete_distribution.cc +0 -98
  1683. data/third_party/abseil-cpp/absl/random/discrete_distribution.h +0 -247
  1684. data/third_party/abseil-cpp/absl/random/distributions.h +0 -452
  1685. data/third_party/abseil-cpp/absl/random/exponential_distribution.h +0 -165
  1686. data/third_party/abseil-cpp/absl/random/gaussian_distribution.cc +0 -104
  1687. data/third_party/abseil-cpp/absl/random/gaussian_distribution.h +0 -275
  1688. data/third_party/abseil-cpp/absl/random/internal/distribution_caller.h +0 -95
  1689. data/third_party/abseil-cpp/absl/random/internal/fast_uniform_bits.h +0 -269
  1690. data/third_party/abseil-cpp/absl/random/internal/fastmath.h +0 -57
  1691. data/third_party/abseil-cpp/absl/random/internal/generate_real.h +0 -144
  1692. data/third_party/abseil-cpp/absl/random/internal/iostream_state_saver.h +0 -245
  1693. data/third_party/abseil-cpp/absl/random/internal/nonsecure_base.h +0 -161
  1694. data/third_party/abseil-cpp/absl/random/internal/pcg_engine.h +0 -308
  1695. data/third_party/abseil-cpp/absl/random/internal/platform.h +0 -171
  1696. data/third_party/abseil-cpp/absl/random/internal/pool_urbg.cc +0 -253
  1697. data/third_party/abseil-cpp/absl/random/internal/pool_urbg.h +0 -131
  1698. data/third_party/abseil-cpp/absl/random/internal/randen.cc +0 -91
  1699. data/third_party/abseil-cpp/absl/random/internal/randen.h +0 -96
  1700. data/third_party/abseil-cpp/absl/random/internal/randen_detect.cc +0 -225
  1701. data/third_party/abseil-cpp/absl/random/internal/randen_detect.h +0 -33
  1702. data/third_party/abseil-cpp/absl/random/internal/randen_engine.h +0 -264
  1703. data/third_party/abseil-cpp/absl/random/internal/randen_hwaes.cc +0 -526
  1704. data/third_party/abseil-cpp/absl/random/internal/randen_hwaes.h +0 -50
  1705. data/third_party/abseil-cpp/absl/random/internal/randen_round_keys.cc +0 -462
  1706. data/third_party/abseil-cpp/absl/random/internal/randen_slow.cc +0 -471
  1707. data/third_party/abseil-cpp/absl/random/internal/randen_slow.h +0 -40
  1708. data/third_party/abseil-cpp/absl/random/internal/randen_traits.h +0 -88
  1709. data/third_party/abseil-cpp/absl/random/internal/salted_seed_seq.h +0 -165
  1710. data/third_party/abseil-cpp/absl/random/internal/seed_material.cc +0 -267
  1711. data/third_party/abseil-cpp/absl/random/internal/seed_material.h +0 -104
  1712. data/third_party/abseil-cpp/absl/random/internal/traits.h +0 -149
  1713. data/third_party/abseil-cpp/absl/random/internal/uniform_helper.h +0 -244
  1714. data/third_party/abseil-cpp/absl/random/internal/wide_multiply.h +0 -96
  1715. data/third_party/abseil-cpp/absl/random/log_uniform_int_distribution.h +0 -256
  1716. data/third_party/abseil-cpp/absl/random/poisson_distribution.h +0 -261
  1717. data/third_party/abseil-cpp/absl/random/random.h +0 -189
  1718. data/third_party/abseil-cpp/absl/random/seed_gen_exception.cc +0 -46
  1719. data/third_party/abseil-cpp/absl/random/seed_gen_exception.h +0 -55
  1720. data/third_party/abseil-cpp/absl/random/seed_sequences.cc +0 -29
  1721. data/third_party/abseil-cpp/absl/random/seed_sequences.h +0 -111
  1722. data/third_party/abseil-cpp/absl/random/uniform_int_distribution.h +0 -275
  1723. data/third_party/abseil-cpp/absl/random/uniform_real_distribution.h +0 -202
  1724. data/third_party/abseil-cpp/absl/random/zipf_distribution.h +0 -272
  1725. data/third_party/abseil-cpp/absl/status/internal/status_internal.h +0 -86
  1726. data/third_party/abseil-cpp/absl/status/internal/statusor_internal.h +0 -396
  1727. data/third_party/abseil-cpp/absl/status/status.cc +0 -616
  1728. data/third_party/abseil-cpp/absl/status/status.h +0 -892
  1729. data/third_party/abseil-cpp/absl/status/status_payload_printer.cc +0 -38
  1730. data/third_party/abseil-cpp/absl/status/status_payload_printer.h +0 -51
  1731. data/third_party/abseil-cpp/absl/status/statusor.cc +0 -103
  1732. data/third_party/abseil-cpp/absl/status/statusor.h +0 -776
  1733. data/third_party/abseil-cpp/absl/strings/ascii.cc +0 -200
  1734. data/third_party/abseil-cpp/absl/strings/ascii.h +0 -242
  1735. data/third_party/abseil-cpp/absl/strings/charconv.cc +0 -984
  1736. data/third_party/abseil-cpp/absl/strings/charconv.h +0 -120
  1737. data/third_party/abseil-cpp/absl/strings/cord.cc +0 -1328
  1738. data/third_party/abseil-cpp/absl/strings/cord.h +0 -1642
  1739. data/third_party/abseil-cpp/absl/strings/cord_analysis.cc +0 -188
  1740. data/third_party/abseil-cpp/absl/strings/cord_analysis.h +0 -44
  1741. data/third_party/abseil-cpp/absl/strings/cord_buffer.cc +0 -30
  1742. data/third_party/abseil-cpp/absl/strings/cord_buffer.h +0 -572
  1743. data/third_party/abseil-cpp/absl/strings/escaping.cc +0 -949
  1744. data/third_party/abseil-cpp/absl/strings/escaping.h +0 -164
  1745. data/third_party/abseil-cpp/absl/strings/internal/char_map.h +0 -156
  1746. data/third_party/abseil-cpp/absl/strings/internal/charconv_bigint.cc +0 -359
  1747. data/third_party/abseil-cpp/absl/strings/internal/charconv_bigint.h +0 -423
  1748. data/third_party/abseil-cpp/absl/strings/internal/charconv_parse.cc +0 -504
  1749. data/third_party/abseil-cpp/absl/strings/internal/charconv_parse.h +0 -99
  1750. data/third_party/abseil-cpp/absl/strings/internal/cord_data_edge.h +0 -63
  1751. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.cc +0 -77
  1752. data/third_party/abseil-cpp/absl/strings/internal/cord_internal.h +0 -655
  1753. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree.cc +0 -1228
  1754. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree.h +0 -924
  1755. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree_navigator.cc +0 -187
  1756. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree_navigator.h +0 -267
  1757. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree_reader.cc +0 -69
  1758. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_btree_reader.h +0 -212
  1759. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_consume.cc +0 -62
  1760. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_consume.h +0 -50
  1761. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_crc.cc +0 -54
  1762. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_crc.h +0 -102
  1763. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_flat.h +0 -187
  1764. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_ring.cc +0 -773
  1765. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_ring.h +0 -607
  1766. data/third_party/abseil-cpp/absl/strings/internal/cord_rep_ring_reader.h +0 -118
  1767. data/third_party/abseil-cpp/absl/strings/internal/cordz_functions.cc +0 -96
  1768. data/third_party/abseil-cpp/absl/strings/internal/cordz_functions.h +0 -85
  1769. data/third_party/abseil-cpp/absl/strings/internal/cordz_handle.cc +0 -139
  1770. data/third_party/abseil-cpp/absl/strings/internal/cordz_handle.h +0 -131
  1771. data/third_party/abseil-cpp/absl/strings/internal/cordz_info.cc +0 -418
  1772. data/third_party/abseil-cpp/absl/strings/internal/cordz_info.h +0 -298
  1773. data/third_party/abseil-cpp/absl/strings/internal/cordz_statistics.h +0 -88
  1774. data/third_party/abseil-cpp/absl/strings/internal/cordz_update_scope.h +0 -71
  1775. data/third_party/abseil-cpp/absl/strings/internal/cordz_update_tracker.h +0 -123
  1776. data/third_party/abseil-cpp/absl/strings/internal/escaping.cc +0 -181
  1777. data/third_party/abseil-cpp/absl/strings/internal/escaping.h +0 -58
  1778. data/third_party/abseil-cpp/absl/strings/internal/memutil.cc +0 -112
  1779. data/third_party/abseil-cpp/absl/strings/internal/memutil.h +0 -148
  1780. data/third_party/abseil-cpp/absl/strings/internal/ostringstream.cc +0 -36
  1781. data/third_party/abseil-cpp/absl/strings/internal/ostringstream.h +0 -89
  1782. data/third_party/abseil-cpp/absl/strings/internal/resize_uninitialized.h +0 -119
  1783. data/third_party/abseil-cpp/absl/strings/internal/stl_type_traits.h +0 -248
  1784. data/third_party/abseil-cpp/absl/strings/internal/str_format/arg.cc +0 -488
  1785. data/third_party/abseil-cpp/absl/strings/internal/str_format/arg.h +0 -526
  1786. data/third_party/abseil-cpp/absl/strings/internal/str_format/bind.cc +0 -258
  1787. data/third_party/abseil-cpp/absl/strings/internal/str_format/bind.h +0 -248
  1788. data/third_party/abseil-cpp/absl/strings/internal/str_format/checker.h +0 -338
  1789. data/third_party/abseil-cpp/absl/strings/internal/str_format/extension.cc +0 -74
  1790. data/third_party/abseil-cpp/absl/strings/internal/str_format/extension.h +0 -448
  1791. data/third_party/abseil-cpp/absl/strings/internal/str_format/float_conversion.cc +0 -1423
  1792. data/third_party/abseil-cpp/absl/strings/internal/str_format/float_conversion.h +0 -37
  1793. data/third_party/abseil-cpp/absl/strings/internal/str_format/output.cc +0 -72
  1794. data/third_party/abseil-cpp/absl/strings/internal/str_format/output.h +0 -97
  1795. data/third_party/abseil-cpp/absl/strings/internal/str_format/parser.cc +0 -339
  1796. data/third_party/abseil-cpp/absl/strings/internal/str_format/parser.h +0 -359
  1797. data/third_party/abseil-cpp/absl/strings/internal/str_join_internal.h +0 -317
  1798. data/third_party/abseil-cpp/absl/strings/internal/str_split_internal.h +0 -430
  1799. data/third_party/abseil-cpp/absl/strings/internal/string_constant.h +0 -72
  1800. data/third_party/abseil-cpp/absl/strings/internal/utf8.cc +0 -53
  1801. data/third_party/abseil-cpp/absl/strings/internal/utf8.h +0 -50
  1802. data/third_party/abseil-cpp/absl/strings/match.cc +0 -43
  1803. data/third_party/abseil-cpp/absl/strings/match.h +0 -100
  1804. data/third_party/abseil-cpp/absl/strings/numbers.cc +0 -1093
  1805. data/third_party/abseil-cpp/absl/strings/numbers.h +0 -303
  1806. data/third_party/abseil-cpp/absl/strings/str_cat.cc +0 -246
  1807. data/third_party/abseil-cpp/absl/strings/str_cat.h +0 -415
  1808. data/third_party/abseil-cpp/absl/strings/str_format.h +0 -812
  1809. data/third_party/abseil-cpp/absl/strings/str_join.h +0 -287
  1810. data/third_party/abseil-cpp/absl/strings/str_replace.cc +0 -82
  1811. data/third_party/abseil-cpp/absl/strings/str_replace.h +0 -219
  1812. data/third_party/abseil-cpp/absl/strings/str_split.cc +0 -139
  1813. data/third_party/abseil-cpp/absl/strings/str_split.h +0 -547
  1814. data/third_party/abseil-cpp/absl/strings/string_view.cc +0 -219
  1815. data/third_party/abseil-cpp/absl/strings/string_view.h +0 -711
  1816. data/third_party/abseil-cpp/absl/strings/strip.h +0 -93
  1817. data/third_party/abseil-cpp/absl/strings/substitute.cc +0 -172
  1818. data/third_party/abseil-cpp/absl/strings/substitute.h +0 -729
  1819. data/third_party/abseil-cpp/absl/synchronization/barrier.cc +0 -52
  1820. data/third_party/abseil-cpp/absl/synchronization/barrier.h +0 -79
  1821. data/third_party/abseil-cpp/absl/synchronization/blocking_counter.cc +0 -67
  1822. data/third_party/abseil-cpp/absl/synchronization/blocking_counter.h +0 -101
  1823. data/third_party/abseil-cpp/absl/synchronization/internal/create_thread_identity.cc +0 -143
  1824. data/third_party/abseil-cpp/absl/synchronization/internal/create_thread_identity.h +0 -56
  1825. data/third_party/abseil-cpp/absl/synchronization/internal/futex.h +0 -154
  1826. data/third_party/abseil-cpp/absl/synchronization/internal/graphcycles.cc +0 -698
  1827. data/third_party/abseil-cpp/absl/synchronization/internal/graphcycles.h +0 -141
  1828. data/third_party/abseil-cpp/absl/synchronization/internal/kernel_timeout.h +0 -156
  1829. data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.cc +0 -102
  1830. data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.h +0 -110
  1831. data/third_party/abseil-cpp/absl/synchronization/internal/waiter.cc +0 -403
  1832. data/third_party/abseil-cpp/absl/synchronization/internal/waiter.h +0 -161
  1833. data/third_party/abseil-cpp/absl/synchronization/mutex.cc +0 -2786
  1834. data/third_party/abseil-cpp/absl/synchronization/mutex.h +0 -1090
  1835. data/third_party/abseil-cpp/absl/synchronization/notification.cc +0 -78
  1836. data/third_party/abseil-cpp/absl/synchronization/notification.h +0 -124
  1837. data/third_party/abseil-cpp/absl/time/civil_time.cc +0 -173
  1838. data/third_party/abseil-cpp/absl/time/civil_time.h +0 -538
  1839. data/third_party/abseil-cpp/absl/time/clock.cc +0 -585
  1840. data/third_party/abseil-cpp/absl/time/clock.h +0 -74
  1841. data/third_party/abseil-cpp/absl/time/duration.cc +0 -955
  1842. data/third_party/abseil-cpp/absl/time/format.cc +0 -160
  1843. data/third_party/abseil-cpp/absl/time/internal/cctz/include/cctz/civil_time.h +0 -332
  1844. data/third_party/abseil-cpp/absl/time/internal/cctz/include/cctz/civil_time_detail.h +0 -632
  1845. data/third_party/abseil-cpp/absl/time/internal/cctz/include/cctz/time_zone.h +0 -459
  1846. data/third_party/abseil-cpp/absl/time/internal/cctz/include/cctz/zone_info_source.h +0 -102
  1847. data/third_party/abseil-cpp/absl/time/internal/cctz/src/civil_time_detail.cc +0 -94
  1848. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_fixed.cc +0 -140
  1849. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_fixed.h +0 -52
  1850. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_format.cc +0 -1029
  1851. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_if.cc +0 -45
  1852. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_if.h +0 -77
  1853. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_impl.cc +0 -113
  1854. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_impl.h +0 -93
  1855. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_info.cc +0 -1027
  1856. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_info.h +0 -137
  1857. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_libc.cc +0 -315
  1858. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_libc.h +0 -55
  1859. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_lookup.cc +0 -236
  1860. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_posix.cc +0 -159
  1861. data/third_party/abseil-cpp/absl/time/internal/cctz/src/time_zone_posix.h +0 -132
  1862. data/third_party/abseil-cpp/absl/time/internal/cctz/src/tzfile.h +0 -122
  1863. data/third_party/abseil-cpp/absl/time/internal/cctz/src/zone_info_source.cc +0 -115
  1864. data/third_party/abseil-cpp/absl/time/internal/get_current_time_chrono.inc +0 -31
  1865. data/third_party/abseil-cpp/absl/time/internal/get_current_time_posix.inc +0 -24
  1866. data/third_party/abseil-cpp/absl/time/time.cc +0 -500
  1867. data/third_party/abseil-cpp/absl/time/time.h +0 -1620
  1868. data/third_party/abseil-cpp/absl/types/bad_optional_access.cc +0 -48
  1869. data/third_party/abseil-cpp/absl/types/bad_optional_access.h +0 -78
  1870. data/third_party/abseil-cpp/absl/types/bad_variant_access.cc +0 -64
  1871. data/third_party/abseil-cpp/absl/types/bad_variant_access.h +0 -82
  1872. data/third_party/abseil-cpp/absl/types/internal/optional.h +0 -404
  1873. data/third_party/abseil-cpp/absl/types/internal/span.h +0 -128
  1874. data/third_party/abseil-cpp/absl/types/internal/variant.h +0 -1646
  1875. data/third_party/abseil-cpp/absl/types/optional.h +0 -779
  1876. data/third_party/abseil-cpp/absl/types/span.h +0 -727
  1877. data/third_party/abseil-cpp/absl/types/variant.h +0 -866
  1878. data/third_party/abseil-cpp/absl/utility/utility.h +0 -350
  1879. data/third_party/address_sorting/address_sorting.c +0 -375
  1880. data/third_party/address_sorting/address_sorting_internal.h +0 -70
  1881. data/third_party/address_sorting/address_sorting_posix.c +0 -98
  1882. data/third_party/address_sorting/address_sorting_windows.c +0 -95
  1883. data/third_party/address_sorting/include/address_sorting/address_sorting.h +0 -115
  1884. data/third_party/boringssl-with-bazel/err_data.c +0 -1493
  1885. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_bitstr.c +0 -284
  1886. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_bool.c +0 -122
  1887. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_d2i_fp.c +0 -91
  1888. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_dup.c +0 -87
  1889. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_enum.c +0 -195
  1890. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_gentm.c +0 -266
  1891. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_i2d_fp.c +0 -88
  1892. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_int.c +0 -420
  1893. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_mbstr.c +0 -298
  1894. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_object.c +0 -299
  1895. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_octet.c +0 -77
  1896. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_print.c +0 -83
  1897. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_strex.c +0 -650
  1898. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_strnid.c +0 -266
  1899. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_time.c +0 -212
  1900. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_type.c +0 -163
  1901. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_utctm.c +0 -264
  1902. data/third_party/boringssl-with-bazel/src/crypto/asn1/a_utf8.c +0 -236
  1903. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn1_lib.c +0 -452
  1904. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn1_par.c +0 -80
  1905. data/third_party/boringssl-with-bazel/src/crypto/asn1/asn_pack.c +0 -101
  1906. data/third_party/boringssl-with-bazel/src/crypto/asn1/charmap.h +0 -15
  1907. data/third_party/boringssl-with-bazel/src/crypto/asn1/f_int.c +0 -102
  1908. data/third_party/boringssl-with-bazel/src/crypto/asn1/f_string.c +0 -91
  1909. data/third_party/boringssl-with-bazel/src/crypto/asn1/internal.h +0 -224
  1910. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_dec.c +0 -969
  1911. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_enc.c +0 -710
  1912. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_fre.c +0 -233
  1913. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_new.c +0 -332
  1914. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_typ.c +0 -131
  1915. data/third_party/boringssl-with-bazel/src/crypto/asn1/tasn_utl.c +0 -281
  1916. data/third_party/boringssl-with-bazel/src/crypto/asn1/time_support.c +0 -206
  1917. data/third_party/boringssl-with-bazel/src/crypto/base64/base64.c +0 -482
  1918. data/third_party/boringssl-with-bazel/src/crypto/bio/bio.c +0 -702
  1919. data/third_party/boringssl-with-bazel/src/crypto/bio/bio_mem.c +0 -324
  1920. data/third_party/boringssl-with-bazel/src/crypto/bio/connect.c +0 -541
  1921. data/third_party/boringssl-with-bazel/src/crypto/bio/fd.c +0 -275
  1922. data/third_party/boringssl-with-bazel/src/crypto/bio/file.c +0 -311
  1923. data/third_party/boringssl-with-bazel/src/crypto/bio/hexdump.c +0 -192
  1924. data/third_party/boringssl-with-bazel/src/crypto/bio/internal.h +0 -111
  1925. data/third_party/boringssl-with-bazel/src/crypto/bio/pair.c +0 -483
  1926. data/third_party/boringssl-with-bazel/src/crypto/bio/printf.c +0 -115
  1927. data/third_party/boringssl-with-bazel/src/crypto/bio/socket.c +0 -192
  1928. data/third_party/boringssl-with-bazel/src/crypto/bio/socket_helper.c +0 -122
  1929. data/third_party/boringssl-with-bazel/src/crypto/blake2/blake2.c +0 -156
  1930. data/third_party/boringssl-with-bazel/src/crypto/bn_extra/bn_asn1.c +0 -57
  1931. data/third_party/boringssl-with-bazel/src/crypto/bn_extra/convert.c +0 -470
  1932. data/third_party/boringssl-with-bazel/src/crypto/buf/buf.c +0 -172
  1933. data/third_party/boringssl-with-bazel/src/crypto/bytestring/asn1_compat.c +0 -52
  1934. data/third_party/boringssl-with-bazel/src/crypto/bytestring/ber.c +0 -266
  1935. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbb.c +0 -728
  1936. data/third_party/boringssl-with-bazel/src/crypto/bytestring/cbs.c +0 -711
  1937. data/third_party/boringssl-with-bazel/src/crypto/bytestring/internal.h +0 -96
  1938. data/third_party/boringssl-with-bazel/src/crypto/bytestring/unicode.c +0 -155
  1939. data/third_party/boringssl-with-bazel/src/crypto/chacha/chacha.c +0 -175
  1940. data/third_party/boringssl-with-bazel/src/crypto/chacha/internal.h +0 -45
  1941. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/cipher_extra.c +0 -127
  1942. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/derive_key.c +0 -152
  1943. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_aesccm.c +0 -447
  1944. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_aesctrhmac.c +0 -283
  1945. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_aesgcmsiv.c +0 -891
  1946. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_chacha20poly1305.c +0 -343
  1947. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_null.c +0 -85
  1948. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_rc2.c +0 -462
  1949. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_rc4.c +0 -87
  1950. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/e_tls.c +0 -601
  1951. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/internal.h +0 -226
  1952. data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/tls_cbc.c +0 -338
  1953. data/third_party/boringssl-with-bazel/src/crypto/cmac/cmac.c +0 -278
  1954. data/third_party/boringssl-with-bazel/src/crypto/conf/conf.c +0 -821
  1955. data/third_party/boringssl-with-bazel/src/crypto/conf/conf_def.h +0 -127
  1956. data/third_party/boringssl-with-bazel/src/crypto/conf/internal.h +0 -31
  1957. data/third_party/boringssl-with-bazel/src/crypto/cpu-aarch64-fuchsia.c +0 -55
  1958. data/third_party/boringssl-with-bazel/src/crypto/cpu-aarch64-linux.c +0 -62
  1959. data/third_party/boringssl-with-bazel/src/crypto/cpu-aarch64-win.c +0 -41
  1960. data/third_party/boringssl-with-bazel/src/crypto/cpu-arm-linux.c +0 -229
  1961. data/third_party/boringssl-with-bazel/src/crypto/cpu-arm-linux.h +0 -201
  1962. data/third_party/boringssl-with-bazel/src/crypto/cpu-arm.c +0 -38
  1963. data/third_party/boringssl-with-bazel/src/crypto/cpu-intel.c +0 -291
  1964. data/third_party/boringssl-with-bazel/src/crypto/cpu-ppc64le.c +0 -38
  1965. data/third_party/boringssl-with-bazel/src/crypto/crypto.c +0 -226
  1966. data/third_party/boringssl-with-bazel/src/crypto/curve25519/curve25519.c +0 -2159
  1967. data/third_party/boringssl-with-bazel/src/crypto/curve25519/curve25519_tables.h +0 -7872
  1968. data/third_party/boringssl-with-bazel/src/crypto/curve25519/internal.h +0 -146
  1969. data/third_party/boringssl-with-bazel/src/crypto/curve25519/spake25519.c +0 -539
  1970. data/third_party/boringssl-with-bazel/src/crypto/dh_extra/dh_asn1.c +0 -160
  1971. data/third_party/boringssl-with-bazel/src/crypto/dh_extra/params.c +0 -272
  1972. data/third_party/boringssl-with-bazel/src/crypto/digest_extra/digest_extra.c +0 -268
  1973. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa.c +0 -967
  1974. data/third_party/boringssl-with-bazel/src/crypto/dsa/dsa_asn1.c +0 -390
  1975. data/third_party/boringssl-with-bazel/src/crypto/dsa/internal.h +0 -34
  1976. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/ec_asn1.c +0 -559
  1977. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/ec_derive.c +0 -95
  1978. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/hash_to_curve.c +0 -385
  1979. data/third_party/boringssl-with-bazel/src/crypto/ec_extra/internal.h +0 -56
  1980. data/third_party/boringssl-with-bazel/src/crypto/ecdh_extra/ecdh_extra.c +0 -124
  1981. data/third_party/boringssl-with-bazel/src/crypto/ecdsa_extra/ecdsa_asn1.c +0 -267
  1982. data/third_party/boringssl-with-bazel/src/crypto/engine/engine.c +0 -99
  1983. data/third_party/boringssl-with-bazel/src/crypto/err/err.c +0 -857
  1984. data/third_party/boringssl-with-bazel/src/crypto/err/internal.h +0 -58
  1985. data/third_party/boringssl-with-bazel/src/crypto/evp/digestsign.c +0 -231
  1986. data/third_party/boringssl-with-bazel/src/crypto/evp/evp.c +0 -456
  1987. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_asn1.c +0 -547
  1988. data/third_party/boringssl-with-bazel/src/crypto/evp/evp_ctx.c +0 -484
  1989. data/third_party/boringssl-with-bazel/src/crypto/evp/internal.h +0 -269
  1990. data/third_party/boringssl-with-bazel/src/crypto/evp/p_dsa_asn1.c +0 -277
  1991. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec.c +0 -286
  1992. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ec_asn1.c +0 -255
  1993. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ed25519.c +0 -104
  1994. data/third_party/boringssl-with-bazel/src/crypto/evp/p_ed25519_asn1.c +0 -221
  1995. data/third_party/boringssl-with-bazel/src/crypto/evp/p_rsa.c +0 -648
  1996. data/third_party/boringssl-with-bazel/src/crypto/evp/p_rsa_asn1.c +0 -194
  1997. data/third_party/boringssl-with-bazel/src/crypto/evp/p_x25519.c +0 -110
  1998. data/third_party/boringssl-with-bazel/src/crypto/evp/p_x25519_asn1.c +0 -248
  1999. data/third_party/boringssl-with-bazel/src/crypto/evp/pbkdf.c +0 -146
  2000. data/third_party/boringssl-with-bazel/src/crypto/evp/print.c +0 -489
  2001. data/third_party/boringssl-with-bazel/src/crypto/evp/scrypt.c +0 -211
  2002. data/third_party/boringssl-with-bazel/src/crypto/evp/sign.c +0 -151
  2003. data/third_party/boringssl-with-bazel/src/crypto/ex_data.c +0 -261
  2004. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/aes.c +0 -108
  2005. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/aes_nohw.c +0 -1282
  2006. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/internal.h +0 -238
  2007. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/key_wrap.c +0 -236
  2008. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/mode_wrappers.c +0 -122
  2009. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bcm.c +0 -266
  2010. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/add.c +0 -316
  2011. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/asm/x86_64-gcc.c +0 -541
  2012. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/bn.c +0 -438
  2013. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/bytes.c +0 -230
  2014. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/cmp.c +0 -200
  2015. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/ctx.c +0 -236
  2016. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div.c +0 -902
  2017. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/div_extra.c +0 -87
  2018. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/exponentiation.c +0 -1288
  2019. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd.c +0 -378
  2020. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/gcd_extra.c +0 -326
  2021. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/generic.c +0 -711
  2022. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/internal.h +0 -715
  2023. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/jacobi.c +0 -146
  2024. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/montgomery.c +0 -502
  2025. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/montgomery_inv.c +0 -186
  2026. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/mul.c +0 -749
  2027. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/prime.c +0 -1064
  2028. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/random.c +0 -341
  2029. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/rsaz_exp.c +0 -226
  2030. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/rsaz_exp.h +0 -104
  2031. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/shift.c +0 -364
  2032. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/sqrt.c +0 -498
  2033. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/aead.c +0 -284
  2034. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/cipher.c +0 -648
  2035. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/e_aes.c +0 -1473
  2036. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/e_des.c +0 -237
  2037. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/cipher/internal.h +0 -128
  2038. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/delocate.h +0 -89
  2039. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/des/des.c +0 -784
  2040. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/des/internal.h +0 -238
  2041. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/check.c +0 -217
  2042. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/dh/dh.c +0 -456
  2043. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/digest.c +0 -282
  2044. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/digests.c +0 -304
  2045. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/internal.h +0 -112
  2046. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/digest/md32_common.h +0 -195
  2047. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec.c +0 -1268
  2048. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_key.c +0 -472
  2049. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/ec_montgomery.c +0 -524
  2050. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/felem.c +0 -100
  2051. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/internal.h +0 -772
  2052. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/oct.c +0 -328
  2053. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p224-64.c +0 -1180
  2054. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256-x86_64-table.h +0 -9497
  2055. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256-x86_64.c +0 -633
  2056. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256-x86_64.h +0 -153
  2057. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256.c +0 -740
  2058. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256_table.h +0 -297
  2059. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/scalar.c +0 -175
  2060. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/simple.c +0 -357
  2061. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/simple_mul.c +0 -270
  2062. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/util.c +0 -255
  2063. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/wnaf.c +0 -270
  2064. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdh/ecdh.c +0 -122
  2065. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdsa/ecdsa.c +0 -338
  2066. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ecdsa/internal.h +0 -39
  2067. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/fips_shared_support.c +0 -32
  2068. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/hmac/hmac.c +0 -228
  2069. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/md4/md4.c +0 -240
  2070. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/md5/internal.h +0 -37
  2071. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/md5/md5.c +0 -284
  2072. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/cbc.c +0 -178
  2073. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/cfb.c +0 -203
  2074. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/ctr.c +0 -201
  2075. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/gcm.c +0 -733
  2076. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/gcm_nohw.c +0 -304
  2077. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/internal.h +0 -420
  2078. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/ofb.c +0 -97
  2079. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/polyval.c +0 -91
  2080. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/ctrdrbg.c +0 -202
  2081. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/fork_detect.c +0 -137
  2082. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/fork_detect.h +0 -49
  2083. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/getrandom_fillin.h +0 -64
  2084. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/internal.h +0 -184
  2085. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/rand.c +0 -457
  2086. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rand/urandom.c +0 -401
  2087. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/blinding.c +0 -243
  2088. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/internal.h +0 -131
  2089. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/padding.c +0 -695
  2090. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa.c +0 -935
  2091. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/rsa/rsa_impl.c +0 -1416
  2092. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/fips.c +0 -79
  2093. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/self_check.c +0 -874
  2094. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/internal.h +0 -53
  2095. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha1-altivec.c +0 -361
  2096. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha1.c +0 -357
  2097. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha256.c +0 -321
  2098. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/sha/sha512.c +0 -508
  2099. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/tls/internal.h +0 -39
  2100. data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/tls/kdf.c +0 -165
  2101. data/third_party/boringssl-with-bazel/src/crypto/hkdf/hkdf.c +0 -112
  2102. data/third_party/boringssl-with-bazel/src/crypto/hpke/hpke.c +0 -618
  2103. data/third_party/boringssl-with-bazel/src/crypto/hrss/hrss.c +0 -2198
  2104. data/third_party/boringssl-with-bazel/src/crypto/hrss/internal.h +0 -68
  2105. data/third_party/boringssl-with-bazel/src/crypto/internal.h +0 -959
  2106. data/third_party/boringssl-with-bazel/src/crypto/lhash/internal.h +0 -253
  2107. data/third_party/boringssl-with-bazel/src/crypto/lhash/lhash.c +0 -353
  2108. data/third_party/boringssl-with-bazel/src/crypto/mem.c +0 -410
  2109. data/third_party/boringssl-with-bazel/src/crypto/obj/obj.c +0 -553
  2110. data/third_party/boringssl-with-bazel/src/crypto/obj/obj_dat.h +0 -11585
  2111. data/third_party/boringssl-with-bazel/src/crypto/obj/obj_xref.c +0 -122
  2112. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_all.c +0 -252
  2113. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_info.c +0 -358
  2114. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_lib.c +0 -769
  2115. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_oth.c +0 -87
  2116. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pk8.c +0 -255
  2117. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_pkey.c +0 -214
  2118. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_x509.c +0 -65
  2119. data/third_party/boringssl-with-bazel/src/crypto/pem/pem_xaux.c +0 -65
  2120. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/internal.h +0 -58
  2121. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/pkcs7.c +0 -193
  2122. data/third_party/boringssl-with-bazel/src/crypto/pkcs7/pkcs7_x509.c +0 -526
  2123. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/internal.h +0 -137
  2124. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/p5_pbev2.c +0 -316
  2125. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8.c +0 -530
  2126. data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8_x509.c +0 -1383
  2127. data/third_party/boringssl-with-bazel/src/crypto/poly1305/internal.h +0 -41
  2128. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305.c +0 -321
  2129. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305_arm.c +0 -307
  2130. data/third_party/boringssl-with-bazel/src/crypto/poly1305/poly1305_vec.c +0 -860
  2131. data/third_party/boringssl-with-bazel/src/crypto/pool/internal.h +0 -49
  2132. data/third_party/boringssl-with-bazel/src/crypto/pool/pool.c +0 -257
  2133. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/deterministic.c +0 -56
  2134. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/forkunsafe.c +0 -46
  2135. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/fuchsia.c +0 -34
  2136. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/passive.c +0 -34
  2137. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/rand_extra.c +0 -74
  2138. data/third_party/boringssl-with-bazel/src/crypto/rand_extra/windows.c +0 -73
  2139. data/third_party/boringssl-with-bazel/src/crypto/rc4/rc4.c +0 -98
  2140. data/third_party/boringssl-with-bazel/src/crypto/refcount_c11.c +0 -67
  2141. data/third_party/boringssl-with-bazel/src/crypto/refcount_lock.c +0 -53
  2142. data/third_party/boringssl-with-bazel/src/crypto/rsa_extra/rsa_asn1.c +0 -324
  2143. data/third_party/boringssl-with-bazel/src/crypto/rsa_extra/rsa_print.c +0 -22
  2144. data/third_party/boringssl-with-bazel/src/crypto/siphash/siphash.c +0 -82
  2145. data/third_party/boringssl-with-bazel/src/crypto/stack/stack.c +0 -425
  2146. data/third_party/boringssl-with-bazel/src/crypto/thread.c +0 -110
  2147. data/third_party/boringssl-with-bazel/src/crypto/thread_none.c +0 -59
  2148. data/third_party/boringssl-with-bazel/src/crypto/thread_pthread.c +0 -182
  2149. data/third_party/boringssl-with-bazel/src/crypto/thread_win.c +0 -260
  2150. data/third_party/boringssl-with-bazel/src/crypto/trust_token/internal.h +0 -318
  2151. data/third_party/boringssl-with-bazel/src/crypto/trust_token/pmbtoken.c +0 -1399
  2152. data/third_party/boringssl-with-bazel/src/crypto/trust_token/trust_token.c +0 -858
  2153. data/third_party/boringssl-with-bazel/src/crypto/trust_token/voprf.c +0 -766
  2154. data/third_party/boringssl-with-bazel/src/crypto/x509/a_digest.c +0 -96
  2155. data/third_party/boringssl-with-bazel/src/crypto/x509/a_sign.c +0 -128
  2156. data/third_party/boringssl-with-bazel/src/crypto/x509/a_verify.c +0 -118
  2157. data/third_party/boringssl-with-bazel/src/crypto/x509/algorithm.c +0 -163
  2158. data/third_party/boringssl-with-bazel/src/crypto/x509/asn1_gen.c +0 -826
  2159. data/third_party/boringssl-with-bazel/src/crypto/x509/by_dir.c +0 -459
  2160. data/third_party/boringssl-with-bazel/src/crypto/x509/by_file.c +0 -277
  2161. data/third_party/boringssl-with-bazel/src/crypto/x509/i2d_pr.c +0 -83
  2162. data/third_party/boringssl-with-bazel/src/crypto/x509/internal.h +0 -404
  2163. data/third_party/boringssl-with-bazel/src/crypto/x509/name_print.c +0 -246
  2164. data/third_party/boringssl-with-bazel/src/crypto/x509/rsa_pss.c +0 -400
  2165. data/third_party/boringssl-with-bazel/src/crypto/x509/t_crl.c +0 -130
  2166. data/third_party/boringssl-with-bazel/src/crypto/x509/t_req.c +0 -246
  2167. data/third_party/boringssl-with-bazel/src/crypto/x509/t_x509.c +0 -365
  2168. data/third_party/boringssl-with-bazel/src/crypto/x509/t_x509a.c +0 -116
  2169. data/third_party/boringssl-with-bazel/src/crypto/x509/x509.c +0 -90
  2170. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_att.c +0 -358
  2171. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_cmp.c +0 -461
  2172. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_d2.c +0 -106
  2173. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_def.c +0 -103
  2174. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_ext.c +0 -212
  2175. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_lu.c +0 -830
  2176. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_obj.c +0 -199
  2177. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_req.c +0 -304
  2178. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_set.c +0 -240
  2179. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_trs.c +0 -331
  2180. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_txt.c +0 -204
  2181. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_v3.c +0 -281
  2182. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vfy.c +0 -2456
  2183. data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vpm.c +0 -651
  2184. data/third_party/boringssl-with-bazel/src/crypto/x509/x509cset.c +0 -284
  2185. data/third_party/boringssl-with-bazel/src/crypto/x509/x509name.c +0 -388
  2186. data/third_party/boringssl-with-bazel/src/crypto/x509/x509rset.c +0 -84
  2187. data/third_party/boringssl-with-bazel/src/crypto/x509/x509spki.c +0 -137
  2188. data/third_party/boringssl-with-bazel/src/crypto/x509/x_algor.c +0 -153
  2189. data/third_party/boringssl-with-bazel/src/crypto/x509/x_all.c +0 -386
  2190. data/third_party/boringssl-with-bazel/src/crypto/x509/x_attrib.c +0 -98
  2191. data/third_party/boringssl-with-bazel/src/crypto/x509/x_crl.c +0 -565
  2192. data/third_party/boringssl-with-bazel/src/crypto/x509/x_exten.c +0 -77
  2193. data/third_party/boringssl-with-bazel/src/crypto/x509/x_info.c +0 -98
  2194. data/third_party/boringssl-with-bazel/src/crypto/x509/x_name.c +0 -544
  2195. data/third_party/boringssl-with-bazel/src/crypto/x509/x_pkey.c +0 -106
  2196. data/third_party/boringssl-with-bazel/src/crypto/x509/x_pubkey.c +0 -217
  2197. data/third_party/boringssl-with-bazel/src/crypto/x509/x_req.c +0 -106
  2198. data/third_party/boringssl-with-bazel/src/crypto/x509/x_sig.c +0 -94
  2199. data/third_party/boringssl-with-bazel/src/crypto/x509/x_spki.c +0 -80
  2200. data/third_party/boringssl-with-bazel/src/crypto/x509/x_val.c +0 -71
  2201. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509.c +0 -394
  2202. data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509a.c +0 -201
  2203. data/third_party/boringssl-with-bazel/src/crypto/x509v3/ext_dat.h +0 -138
  2204. data/third_party/boringssl-with-bazel/src/crypto/x509v3/internal.h +0 -289
  2205. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_cache.c +0 -287
  2206. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_data.c +0 -132
  2207. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_lib.c +0 -155
  2208. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_map.c +0 -131
  2209. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_node.c +0 -189
  2210. data/third_party/boringssl-with-bazel/src/crypto/x509v3/pcy_tree.c +0 -843
  2211. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_akey.c +0 -226
  2212. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_akeya.c +0 -72
  2213. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_alt.c +0 -640
  2214. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_bcons.c +0 -133
  2215. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_bitst.c +0 -144
  2216. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_conf.c +0 -468
  2217. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_cpols.c +0 -500
  2218. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_crld.c +0 -563
  2219. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_enum.c +0 -106
  2220. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_extku.c +0 -148
  2221. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_genn.c +0 -266
  2222. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_ia5.c +0 -121
  2223. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_info.c +0 -218
  2224. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_int.c +0 -91
  2225. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_lib.c +0 -379
  2226. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_ncons.c +0 -558
  2227. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_ocsp.c +0 -68
  2228. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_pci.c +0 -289
  2229. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_pcia.c +0 -57
  2230. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_pcons.c +0 -139
  2231. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_pmaps.c +0 -154
  2232. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_prn.c +0 -230
  2233. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_purp.c +0 -929
  2234. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_skey.c +0 -156
  2235. data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_utl.c +0 -1437
  2236. data/third_party/boringssl-with-bazel/src/include/openssl/aead.h +0 -480
  2237. data/third_party/boringssl-with-bazel/src/include/openssl/aes.h +0 -207
  2238. data/third_party/boringssl-with-bazel/src/include/openssl/arm_arch.h +0 -240
  2239. data/third_party/boringssl-with-bazel/src/include/openssl/asn1.h +0 -2039
  2240. data/third_party/boringssl-with-bazel/src/include/openssl/asn1_mac.h +0 -18
  2241. data/third_party/boringssl-with-bazel/src/include/openssl/asn1t.h +0 -718
  2242. data/third_party/boringssl-with-bazel/src/include/openssl/base.h +0 -627
  2243. data/third_party/boringssl-with-bazel/src/include/openssl/base64.h +0 -198
  2244. data/third_party/boringssl-with-bazel/src/include/openssl/bio.h +0 -939
  2245. data/third_party/boringssl-with-bazel/src/include/openssl/blake2.h +0 -62
  2246. data/third_party/boringssl-with-bazel/src/include/openssl/blowfish.h +0 -93
  2247. data/third_party/boringssl-with-bazel/src/include/openssl/bn.h +0 -1057
  2248. data/third_party/boringssl-with-bazel/src/include/openssl/buf.h +0 -137
  2249. data/third_party/boringssl-with-bazel/src/include/openssl/buffer.h +0 -18
  2250. data/third_party/boringssl-with-bazel/src/include/openssl/bytestring.h +0 -586
  2251. data/third_party/boringssl-with-bazel/src/include/openssl/cast.h +0 -96
  2252. data/third_party/boringssl-with-bazel/src/include/openssl/chacha.h +0 -41
  2253. data/third_party/boringssl-with-bazel/src/include/openssl/cipher.h +0 -673
  2254. data/third_party/boringssl-with-bazel/src/include/openssl/cmac.h +0 -91
  2255. data/third_party/boringssl-with-bazel/src/include/openssl/conf.h +0 -183
  2256. data/third_party/boringssl-with-bazel/src/include/openssl/cpu.h +0 -202
  2257. data/third_party/boringssl-with-bazel/src/include/openssl/crypto.h +0 -169
  2258. data/third_party/boringssl-with-bazel/src/include/openssl/curve25519.h +0 -201
  2259. data/third_party/boringssl-with-bazel/src/include/openssl/des.h +0 -183
  2260. data/third_party/boringssl-with-bazel/src/include/openssl/dh.h +0 -353
  2261. data/third_party/boringssl-with-bazel/src/include/openssl/digest.h +0 -348
  2262. data/third_party/boringssl-with-bazel/src/include/openssl/dsa.h +0 -443
  2263. data/third_party/boringssl-with-bazel/src/include/openssl/dtls1.h +0 -16
  2264. data/third_party/boringssl-with-bazel/src/include/openssl/e_os2.h +0 -18
  2265. data/third_party/boringssl-with-bazel/src/include/openssl/ec.h +0 -442
  2266. data/third_party/boringssl-with-bazel/src/include/openssl/ec_key.h +0 -357
  2267. data/third_party/boringssl-with-bazel/src/include/openssl/ecdh.h +0 -118
  2268. data/third_party/boringssl-with-bazel/src/include/openssl/ecdsa.h +0 -236
  2269. data/third_party/boringssl-with-bazel/src/include/openssl/engine.h +0 -109
  2270. data/third_party/boringssl-with-bazel/src/include/openssl/err.h +0 -466
  2271. data/third_party/boringssl-with-bazel/src/include/openssl/evp.h +0 -1083
  2272. data/third_party/boringssl-with-bazel/src/include/openssl/evp_errors.h +0 -99
  2273. data/third_party/boringssl-with-bazel/src/include/openssl/ex_data.h +0 -203
  2274. data/third_party/boringssl-with-bazel/src/include/openssl/hkdf.h +0 -68
  2275. data/third_party/boringssl-with-bazel/src/include/openssl/hmac.h +0 -186
  2276. data/third_party/boringssl-with-bazel/src/include/openssl/hpke.h +0 -350
  2277. data/third_party/boringssl-with-bazel/src/include/openssl/hrss.h +0 -102
  2278. data/third_party/boringssl-with-bazel/src/include/openssl/is_boringssl.h +0 -16
  2279. data/third_party/boringssl-with-bazel/src/include/openssl/lhash.h +0 -81
  2280. data/third_party/boringssl-with-bazel/src/include/openssl/md4.h +0 -108
  2281. data/third_party/boringssl-with-bazel/src/include/openssl/md5.h +0 -109
  2282. data/third_party/boringssl-with-bazel/src/include/openssl/mem.h +0 -184
  2283. data/third_party/boringssl-with-bazel/src/include/openssl/nid.h +0 -4259
  2284. data/third_party/boringssl-with-bazel/src/include/openssl/obj.h +0 -256
  2285. data/third_party/boringssl-with-bazel/src/include/openssl/obj_mac.h +0 -18
  2286. data/third_party/boringssl-with-bazel/src/include/openssl/objects.h +0 -18
  2287. data/third_party/boringssl-with-bazel/src/include/openssl/opensslconf.h +0 -70
  2288. data/third_party/boringssl-with-bazel/src/include/openssl/opensslv.h +0 -18
  2289. data/third_party/boringssl-with-bazel/src/include/openssl/ossl_typ.h +0 -18
  2290. data/third_party/boringssl-with-bazel/src/include/openssl/pem.h +0 -483
  2291. data/third_party/boringssl-with-bazel/src/include/openssl/pkcs12.h +0 -18
  2292. data/third_party/boringssl-with-bazel/src/include/openssl/pkcs7.h +0 -239
  2293. data/third_party/boringssl-with-bazel/src/include/openssl/pkcs8.h +0 -282
  2294. data/third_party/boringssl-with-bazel/src/include/openssl/poly1305.h +0 -49
  2295. data/third_party/boringssl-with-bazel/src/include/openssl/pool.h +0 -108
  2296. data/third_party/boringssl-with-bazel/src/include/openssl/rand.h +0 -114
  2297. data/third_party/boringssl-with-bazel/src/include/openssl/rc4.h +0 -96
  2298. data/third_party/boringssl-with-bazel/src/include/openssl/ripemd.h +0 -108
  2299. data/third_party/boringssl-with-bazel/src/include/openssl/rsa.h +0 -855
  2300. data/third_party/boringssl-with-bazel/src/include/openssl/safestack.h +0 -16
  2301. data/third_party/boringssl-with-bazel/src/include/openssl/sha.h +0 -294
  2302. data/third_party/boringssl-with-bazel/src/include/openssl/siphash.h +0 -37
  2303. data/third_party/boringssl-with-bazel/src/include/openssl/span.h +0 -222
  2304. data/third_party/boringssl-with-bazel/src/include/openssl/srtp.h +0 -18
  2305. data/third_party/boringssl-with-bazel/src/include/openssl/ssl.h +0 -5624
  2306. data/third_party/boringssl-with-bazel/src/include/openssl/ssl3.h +0 -333
  2307. data/third_party/boringssl-with-bazel/src/include/openssl/stack.h +0 -542
  2308. data/third_party/boringssl-with-bazel/src/include/openssl/thread.h +0 -191
  2309. data/third_party/boringssl-with-bazel/src/include/openssl/tls1.h +0 -647
  2310. data/third_party/boringssl-with-bazel/src/include/openssl/trust_token.h +0 -310
  2311. data/third_party/boringssl-with-bazel/src/include/openssl/type_check.h +0 -90
  2312. data/third_party/boringssl-with-bazel/src/include/openssl/x509.h +0 -2419
  2313. data/third_party/boringssl-with-bazel/src/include/openssl/x509_vfy.h +0 -18
  2314. data/third_party/boringssl-with-bazel/src/include/openssl/x509v3.h +0 -1021
  2315. data/third_party/boringssl-with-bazel/src/ssl/bio_ssl.cc +0 -192
  2316. data/third_party/boringssl-with-bazel/src/ssl/d1_both.cc +0 -835
  2317. data/third_party/boringssl-with-bazel/src/ssl/d1_lib.cc +0 -268
  2318. data/third_party/boringssl-with-bazel/src/ssl/d1_pkt.cc +0 -273
  2319. data/third_party/boringssl-with-bazel/src/ssl/d1_srtp.cc +0 -232
  2320. data/third_party/boringssl-with-bazel/src/ssl/dtls_method.cc +0 -200
  2321. data/third_party/boringssl-with-bazel/src/ssl/dtls_record.cc +0 -353
  2322. data/third_party/boringssl-with-bazel/src/ssl/encrypted_client_hello.cc +0 -1084
  2323. data/third_party/boringssl-with-bazel/src/ssl/extensions.cc +0 -4325
  2324. data/third_party/boringssl-with-bazel/src/ssl/handoff.cc +0 -986
  2325. data/third_party/boringssl-with-bazel/src/ssl/handshake.cc +0 -758
  2326. data/third_party/boringssl-with-bazel/src/ssl/handshake_client.cc +0 -1986
  2327. data/third_party/boringssl-with-bazel/src/ssl/handshake_server.cc +0 -1956
  2328. data/third_party/boringssl-with-bazel/src/ssl/internal.h +0 -3953
  2329. data/third_party/boringssl-with-bazel/src/ssl/s3_both.cc +0 -730
  2330. data/third_party/boringssl-with-bazel/src/ssl/s3_lib.cc +0 -219
  2331. data/third_party/boringssl-with-bazel/src/ssl/s3_pkt.cc +0 -453
  2332. data/third_party/boringssl-with-bazel/src/ssl/ssl_aead_ctx.cc +0 -432
  2333. data/third_party/boringssl-with-bazel/src/ssl/ssl_asn1.cc +0 -896
  2334. data/third_party/boringssl-with-bazel/src/ssl/ssl_buffer.cc +0 -306
  2335. data/third_party/boringssl-with-bazel/src/ssl/ssl_cert.cc +0 -1014
  2336. data/third_party/boringssl-with-bazel/src/ssl/ssl_cipher.cc +0 -1717
  2337. data/third_party/boringssl-with-bazel/src/ssl/ssl_file.cc +0 -585
  2338. data/third_party/boringssl-with-bazel/src/ssl/ssl_key_share.cc +0 -400
  2339. data/third_party/boringssl-with-bazel/src/ssl/ssl_lib.cc +0 -3072
  2340. data/third_party/boringssl-with-bazel/src/ssl/ssl_privkey.cc +0 -837
  2341. data/third_party/boringssl-with-bazel/src/ssl/ssl_session.cc +0 -1342
  2342. data/third_party/boringssl-with-bazel/src/ssl/ssl_stat.cc +0 -233
  2343. data/third_party/boringssl-with-bazel/src/ssl/ssl_transcript.cc +0 -272
  2344. data/third_party/boringssl-with-bazel/src/ssl/ssl_versions.cc +0 -402
  2345. data/third_party/boringssl-with-bazel/src/ssl/ssl_x509.cc +0 -1363
  2346. data/third_party/boringssl-with-bazel/src/ssl/t1_enc.cc +0 -384
  2347. data/third_party/boringssl-with-bazel/src/ssl/tls13_both.cc +0 -733
  2348. data/third_party/boringssl-with-bazel/src/ssl/tls13_client.cc +0 -1122
  2349. data/third_party/boringssl-with-bazel/src/ssl/tls13_enc.cc +0 -582
  2350. data/third_party/boringssl-with-bazel/src/ssl/tls13_server.cc +0 -1349
  2351. data/third_party/boringssl-with-bazel/src/ssl/tls_method.cc +0 -319
  2352. data/third_party/boringssl-with-bazel/src/ssl/tls_record.cc +0 -705
  2353. data/third_party/boringssl-with-bazel/src/third_party/fiat/curve25519_32.h +0 -981
  2354. data/third_party/boringssl-with-bazel/src/third_party/fiat/curve25519_64.h +0 -619
  2355. data/third_party/boringssl-with-bazel/src/third_party/fiat/p256_32.h +0 -3147
  2356. data/third_party/boringssl-with-bazel/src/third_party/fiat/p256_64.h +0 -1226
  2357. data/third_party/cares/ares_build.h +0 -223
  2358. data/third_party/cares/cares/include/ares.h +0 -742
  2359. data/third_party/cares/cares/include/ares_dns.h +0 -112
  2360. data/third_party/cares/cares/include/ares_rules.h +0 -125
  2361. data/third_party/cares/cares/include/ares_version.h +0 -24
  2362. data/third_party/cares/cares/src/lib/ares__close_sockets.c +0 -61
  2363. data/third_party/cares/cares/src/lib/ares__get_hostent.c +0 -260
  2364. data/third_party/cares/cares/src/lib/ares__parse_into_addrinfo.c +0 -260
  2365. data/third_party/cares/cares/src/lib/ares__read_line.c +0 -73
  2366. data/third_party/cares/cares/src/lib/ares__readaddrinfo.c +0 -264
  2367. data/third_party/cares/cares/src/lib/ares__sortaddrinfo.c +0 -499
  2368. data/third_party/cares/cares/src/lib/ares__timeval.c +0 -111
  2369. data/third_party/cares/cares/src/lib/ares_android.c +0 -444
  2370. data/third_party/cares/cares/src/lib/ares_android.h +0 -27
  2371. data/third_party/cares/cares/src/lib/ares_cancel.c +0 -63
  2372. data/third_party/cares/cares/src/lib/ares_create_query.c +0 -197
  2373. data/third_party/cares/cares/src/lib/ares_data.c +0 -240
  2374. data/third_party/cares/cares/src/lib/ares_data.h +0 -74
  2375. data/third_party/cares/cares/src/lib/ares_destroy.c +0 -113
  2376. data/third_party/cares/cares/src/lib/ares_expand_name.c +0 -300
  2377. data/third_party/cares/cares/src/lib/ares_expand_string.c +0 -67
  2378. data/third_party/cares/cares/src/lib/ares_fds.c +0 -59
  2379. data/third_party/cares/cares/src/lib/ares_free_hostent.c +0 -43
  2380. data/third_party/cares/cares/src/lib/ares_free_string.c +0 -25
  2381. data/third_party/cares/cares/src/lib/ares_freeaddrinfo.c +0 -59
  2382. data/third_party/cares/cares/src/lib/ares_getaddrinfo.c +0 -772
  2383. data/third_party/cares/cares/src/lib/ares_getenv.c +0 -28
  2384. data/third_party/cares/cares/src/lib/ares_getenv.h +0 -26
  2385. data/third_party/cares/cares/src/lib/ares_gethostbyaddr.c +0 -287
  2386. data/third_party/cares/cares/src/lib/ares_gethostbyname.c +0 -534
  2387. data/third_party/cares/cares/src/lib/ares_getnameinfo.c +0 -447
  2388. data/third_party/cares/cares/src/lib/ares_getsock.c +0 -66
  2389. data/third_party/cares/cares/src/lib/ares_inet_net_pton.h +0 -25
  2390. data/third_party/cares/cares/src/lib/ares_init.c +0 -2654
  2391. data/third_party/cares/cares/src/lib/ares_iphlpapi.h +0 -221
  2392. data/third_party/cares/cares/src/lib/ares_ipv6.h +0 -85
  2393. data/third_party/cares/cares/src/lib/ares_library_init.c +0 -200
  2394. data/third_party/cares/cares/src/lib/ares_library_init.h +0 -43
  2395. data/third_party/cares/cares/src/lib/ares_llist.c +0 -63
  2396. data/third_party/cares/cares/src/lib/ares_llist.h +0 -39
  2397. data/third_party/cares/cares/src/lib/ares_mkquery.c +0 -24
  2398. data/third_party/cares/cares/src/lib/ares_nameser.h +0 -482
  2399. data/third_party/cares/cares/src/lib/ares_nowarn.c +0 -260
  2400. data/third_party/cares/cares/src/lib/ares_nowarn.h +0 -61
  2401. data/third_party/cares/cares/src/lib/ares_options.c +0 -406
  2402. data/third_party/cares/cares/src/lib/ares_parse_a_reply.c +0 -209
  2403. data/third_party/cares/cares/src/lib/ares_parse_aaaa_reply.c +0 -212
  2404. data/third_party/cares/cares/src/lib/ares_parse_caa_reply.c +0 -199
  2405. data/third_party/cares/cares/src/lib/ares_parse_mx_reply.c +0 -164
  2406. data/third_party/cares/cares/src/lib/ares_parse_naptr_reply.c +0 -183
  2407. data/third_party/cares/cares/src/lib/ares_parse_ns_reply.c +0 -177
  2408. data/third_party/cares/cares/src/lib/ares_parse_ptr_reply.c +0 -228
  2409. data/third_party/cares/cares/src/lib/ares_parse_soa_reply.c +0 -179
  2410. data/third_party/cares/cares/src/lib/ares_parse_srv_reply.c +0 -168
  2411. data/third_party/cares/cares/src/lib/ares_parse_txt_reply.c +0 -214
  2412. data/third_party/cares/cares/src/lib/ares_platform.c +0 -11042
  2413. data/third_party/cares/cares/src/lib/ares_platform.h +0 -43
  2414. data/third_party/cares/cares/src/lib/ares_private.h +0 -423
  2415. data/third_party/cares/cares/src/lib/ares_process.c +0 -1548
  2416. data/third_party/cares/cares/src/lib/ares_query.c +0 -180
  2417. data/third_party/cares/cares/src/lib/ares_search.c +0 -321
  2418. data/third_party/cares/cares/src/lib/ares_send.c +0 -131
  2419. data/third_party/cares/cares/src/lib/ares_setup.h +0 -220
  2420. data/third_party/cares/cares/src/lib/ares_strcasecmp.c +0 -66
  2421. data/third_party/cares/cares/src/lib/ares_strcasecmp.h +0 -30
  2422. data/third_party/cares/cares/src/lib/ares_strdup.c +0 -49
  2423. data/third_party/cares/cares/src/lib/ares_strdup.h +0 -24
  2424. data/third_party/cares/cares/src/lib/ares_strerror.c +0 -56
  2425. data/third_party/cares/cares/src/lib/ares_strsplit.c +0 -178
  2426. data/third_party/cares/cares/src/lib/ares_strsplit.h +0 -43
  2427. data/third_party/cares/cares/src/lib/ares_timeout.c +0 -88
  2428. data/third_party/cares/cares/src/lib/ares_version.c +0 -11
  2429. data/third_party/cares/cares/src/lib/ares_writev.c +0 -79
  2430. data/third_party/cares/cares/src/lib/ares_writev.h +0 -36
  2431. data/third_party/cares/cares/src/lib/bitncmp.c +0 -59
  2432. data/third_party/cares/cares/src/lib/bitncmp.h +0 -26
  2433. data/third_party/cares/cares/src/lib/config-dos.h +0 -115
  2434. data/third_party/cares/cares/src/lib/config-win32.h +0 -351
  2435. data/third_party/cares/cares/src/lib/inet_net_pton.c +0 -444
  2436. data/third_party/cares/cares/src/lib/inet_ntop.c +0 -201
  2437. data/third_party/cares/cares/src/lib/setup_once.h +0 -554
  2438. data/third_party/cares/cares/src/lib/windows_port.c +0 -22
  2439. data/third_party/cares/config_darwin/ares_config.h +0 -428
  2440. data/third_party/cares/config_freebsd/ares_config.h +0 -505
  2441. data/third_party/cares/config_linux/ares_config.h +0 -461
  2442. data/third_party/cares/config_openbsd/ares_config.h +0 -505
  2443. data/third_party/re2/re2/bitmap256.h +0 -117
  2444. data/third_party/re2/re2/bitstate.cc +0 -385
  2445. data/third_party/re2/re2/compile.cc +0 -1261
  2446. data/third_party/re2/re2/dfa.cc +0 -2118
  2447. data/third_party/re2/re2/filtered_re2.cc +0 -137
  2448. data/third_party/re2/re2/filtered_re2.h +0 -114
  2449. data/third_party/re2/re2/mimics_pcre.cc +0 -197
  2450. data/third_party/re2/re2/nfa.cc +0 -713
  2451. data/third_party/re2/re2/onepass.cc +0 -623
  2452. data/third_party/re2/re2/parse.cc +0 -2483
  2453. data/third_party/re2/re2/perl_groups.cc +0 -119
  2454. data/third_party/re2/re2/pod_array.h +0 -55
  2455. data/third_party/re2/re2/prefilter.cc +0 -711
  2456. data/third_party/re2/re2/prefilter.h +0 -108
  2457. data/third_party/re2/re2/prefilter_tree.cc +0 -407
  2458. data/third_party/re2/re2/prefilter_tree.h +0 -139
  2459. data/third_party/re2/re2/prog.cc +0 -1166
  2460. data/third_party/re2/re2/prog.h +0 -455
  2461. data/third_party/re2/re2/re2.cc +0 -1331
  2462. data/third_party/re2/re2/re2.h +0 -1017
  2463. data/third_party/re2/re2/regexp.cc +0 -987
  2464. data/third_party/re2/re2/regexp.h +0 -665
  2465. data/third_party/re2/re2/set.cc +0 -176
  2466. data/third_party/re2/re2/set.h +0 -85
  2467. data/third_party/re2/re2/simplify.cc +0 -665
  2468. data/third_party/re2/re2/sparse_array.h +0 -392
  2469. data/third_party/re2/re2/sparse_set.h +0 -264
  2470. data/third_party/re2/re2/stringpiece.cc +0 -65
  2471. data/third_party/re2/re2/stringpiece.h +0 -210
  2472. data/third_party/re2/re2/tostring.cc +0 -351
  2473. data/third_party/re2/re2/unicode_casefold.cc +0 -582
  2474. data/third_party/re2/re2/unicode_casefold.h +0 -78
  2475. data/third_party/re2/re2/unicode_groups.cc +0 -6269
  2476. data/third_party/re2/re2/unicode_groups.h +0 -67
  2477. data/third_party/re2/re2/walker-inl.h +0 -246
  2478. data/third_party/re2/util/benchmark.h +0 -156
  2479. data/third_party/re2/util/flags.h +0 -26
  2480. data/third_party/re2/util/logging.h +0 -109
  2481. data/third_party/re2/util/malloc_counter.h +0 -19
  2482. data/third_party/re2/util/mix.h +0 -41
  2483. data/third_party/re2/util/mutex.h +0 -148
  2484. data/third_party/re2/util/pcre.cc +0 -1025
  2485. data/third_party/re2/util/pcre.h +0 -681
  2486. data/third_party/re2/util/rune.cc +0 -260
  2487. data/third_party/re2/util/strutil.cc +0 -149
  2488. data/third_party/re2/util/strutil.h +0 -21
  2489. data/third_party/re2/util/test.h +0 -50
  2490. data/third_party/re2/util/utf.h +0 -44
  2491. data/third_party/re2/util/util.h +0 -42
  2492. data/third_party/upb/third_party/utf8_range/naive.c +0 -92
  2493. data/third_party/upb/third_party/utf8_range/range2-neon.c +0 -157
  2494. data/third_party/upb/third_party/utf8_range/range2-sse.c +0 -170
  2495. data/third_party/upb/third_party/utf8_range/utf8_range.h +0 -9
  2496. data/third_party/upb/upb/arena.c +0 -277
  2497. data/third_party/upb/upb/arena.h +0 -225
  2498. data/third_party/upb/upb/array.c +0 -114
  2499. data/third_party/upb/upb/array.h +0 -83
  2500. data/third_party/upb/upb/collections.h +0 -36
  2501. data/third_party/upb/upb/decode.c +0 -1221
  2502. data/third_party/upb/upb/decode.h +0 -95
  2503. data/third_party/upb/upb/decode_fast.c +0 -1055
  2504. data/third_party/upb/upb/decode_fast.h +0 -153
  2505. data/third_party/upb/upb/def.c +0 -3269
  2506. data/third_party/upb/upb/def.h +0 -416
  2507. data/third_party/upb/upb/def.hpp +0 -441
  2508. data/third_party/upb/upb/encode.c +0 -613
  2509. data/third_party/upb/upb/encode.h +0 -81
  2510. data/third_party/upb/upb/extension_registry.c +0 -93
  2511. data/third_party/upb/upb/extension_registry.h +0 -84
  2512. data/third_party/upb/upb/internal/decode.h +0 -211
  2513. data/third_party/upb/upb/internal/table.h +0 -385
  2514. data/third_party/upb/upb/internal/upb.h +0 -68
  2515. data/third_party/upb/upb/internal/vsnprintf_compat.h +0 -52
  2516. data/third_party/upb/upb/json_decode.c +0 -1512
  2517. data/third_party/upb/upb/json_decode.h +0 -47
  2518. data/third_party/upb/upb/json_encode.c +0 -780
  2519. data/third_party/upb/upb/json_encode.h +0 -65
  2520. data/third_party/upb/upb/map.c +0 -108
  2521. data/third_party/upb/upb/map.h +0 -117
  2522. data/third_party/upb/upb/message_value.h +0 -66
  2523. data/third_party/upb/upb/mini_table.c +0 -1147
  2524. data/third_party/upb/upb/mini_table.h +0 -189
  2525. data/third_party/upb/upb/mini_table.hpp +0 -112
  2526. data/third_party/upb/upb/msg.c +0 -368
  2527. data/third_party/upb/upb/msg.h +0 -71
  2528. data/third_party/upb/upb/msg_internal.h +0 -837
  2529. data/third_party/upb/upb/port_def.inc +0 -262
  2530. data/third_party/upb/upb/port_undef.inc +0 -63
  2531. data/third_party/upb/upb/reflection.c +0 -323
  2532. data/third_party/upb/upb/reflection.h +0 -110
  2533. data/third_party/upb/upb/reflection.hpp +0 -37
  2534. data/third_party/upb/upb/status.c +0 -86
  2535. data/third_party/upb/upb/status.h +0 -66
  2536. data/third_party/upb/upb/table.c +0 -926
  2537. data/third_party/upb/upb/table_internal.h +0 -36
  2538. data/third_party/upb/upb/text_encode.c +0 -473
  2539. data/third_party/upb/upb/text_encode.h +0 -64
  2540. data/third_party/upb/upb/upb.c +0 -76
  2541. data/third_party/upb/upb/upb.h +0 -184
  2542. data/third_party/upb/upb/upb.hpp +0 -115
  2543. data/third_party/xxhash/xxhash.h +0 -5580
  2544. data/third_party/zlib/adler32.c +0 -186
  2545. data/third_party/zlib/compress.c +0 -86
  2546. data/third_party/zlib/crc32.c +0 -1116
  2547. data/third_party/zlib/crc32.h +0 -9446
  2548. data/third_party/zlib/deflate.c +0 -2211
  2549. data/third_party/zlib/deflate.h +0 -346
  2550. data/third_party/zlib/gzclose.c +0 -25
  2551. data/third_party/zlib/gzguts.h +0 -219
  2552. data/third_party/zlib/gzlib.c +0 -639
  2553. data/third_party/zlib/gzread.c +0 -652
  2554. data/third_party/zlib/gzwrite.c +0 -677
  2555. data/third_party/zlib/infback.c +0 -641
  2556. data/third_party/zlib/inffast.c +0 -323
  2557. data/third_party/zlib/inffast.h +0 -11
  2558. data/third_party/zlib/inffixed.h +0 -94
  2559. data/third_party/zlib/inflate.c +0 -1592
  2560. data/third_party/zlib/inflate.h +0 -126
  2561. data/third_party/zlib/inftrees.c +0 -304
  2562. data/third_party/zlib/inftrees.h +0 -62
  2563. data/third_party/zlib/trees.c +0 -1182
  2564. data/third_party/zlib/trees.h +0 -128
  2565. data/third_party/zlib/uncompr.c +0 -93
  2566. data/third_party/zlib/zconf.h +0 -534
  2567. data/third_party/zlib/zlib.h +0 -1935
  2568. data/third_party/zlib/zutil.c +0 -325
  2569. data/third_party/zlib/zutil.h +0 -274
@@ -1,2683 +0,0 @@
1
- //
2
- // Copyright 2015 gRPC authors.
3
- //
4
- // Licensed under the Apache License, Version 2.0 (the "License");
5
- // you may not use this file except in compliance with the License.
6
- // You may obtain a copy of the License at
7
- //
8
- // http://www.apache.org/licenses/LICENSE-2.0
9
- //
10
- // Unless required by applicable law or agreed to in writing, software
11
- // distributed under the License is distributed on an "AS IS" BASIS,
12
- // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
- // See the License for the specific language governing permissions and
14
- // limitations under the License.
15
- //
16
-
17
- #include <grpc/support/port_platform.h>
18
-
19
- #include "src/core/ext/filters/client_channel/retry_filter.h"
20
-
21
- #include <inttypes.h>
22
- #include <limits.h>
23
- #include <stddef.h>
24
-
25
- #include <memory>
26
- #include <new>
27
- #include <string>
28
- #include <utility>
29
-
30
- #include "absl/container/inlined_vector.h"
31
- #include "absl/status/statusor.h"
32
- #include "absl/strings/str_cat.h"
33
- #include "absl/strings/string_view.h"
34
- #include "absl/strings/strip.h"
35
- #include "absl/types/optional.h"
36
-
37
- #include <grpc/impl/codegen/grpc_types.h>
38
- #include <grpc/slice.h>
39
- #include <grpc/status.h>
40
- #include <grpc/support/atm.h>
41
- #include <grpc/support/log.h>
42
-
43
- #include "src/core/ext/filters/client_channel/client_channel.h"
44
- #include "src/core/ext/filters/client_channel/config_selector.h"
45
- #include "src/core/ext/filters/client_channel/retry_service_config.h"
46
- #include "src/core/ext/filters/client_channel/retry_throttle.h"
47
- #include "src/core/lib/backoff/backoff.h"
48
- #include "src/core/lib/channel/channel_args.h"
49
- #include "src/core/lib/channel/channel_stack.h"
50
- #include "src/core/lib/channel/context.h"
51
- #include "src/core/lib/channel/status_util.h"
52
- #include "src/core/lib/debug/trace.h"
53
- #include "src/core/lib/gpr/useful.h"
54
- #include "src/core/lib/gprpp/construct_destruct.h"
55
- #include "src/core/lib/gprpp/debug_location.h"
56
- #include "src/core/lib/gprpp/orphanable.h"
57
- #include "src/core/lib/gprpp/ref_counted.h"
58
- #include "src/core/lib/gprpp/ref_counted_ptr.h"
59
- #include "src/core/lib/gprpp/time.h"
60
- #include "src/core/lib/iomgr/call_combiner.h"
61
- #include "src/core/lib/iomgr/closure.h"
62
- #include "src/core/lib/iomgr/error.h"
63
- #include "src/core/lib/iomgr/exec_ctx.h"
64
- #include "src/core/lib/iomgr/polling_entity.h"
65
- #include "src/core/lib/iomgr/timer.h"
66
- #include "src/core/lib/resource_quota/arena.h"
67
- #include "src/core/lib/service_config/service_config.h"
68
- #include "src/core/lib/service_config/service_config_call_data.h"
69
- #include "src/core/lib/slice/slice_buffer.h"
70
- #include "src/core/lib/slice/slice_refcount.h"
71
- #include "src/core/lib/transport/error_utils.h"
72
- #include "src/core/lib/transport/metadata_batch.h"
73
- #include "src/core/lib/transport/transport.h"
74
- #include "src/core/lib/uri/uri_parser.h"
75
-
76
- //
77
- // Retry filter
78
- //
79
-
80
- // This filter is intended to be used in the DynamicFilter stack in the
81
- // client channel, which is situated between the name resolver and the
82
- // LB policy. Normally, the last filter in the DynamicFilter stack is
83
- // the DynamicTerminationFilter (see client_channel.cc), which creates a
84
- // LoadBalancedCall and delegates to it. However, when retries are
85
- // enabled, this filter is used instead of the DynamicTerminationFilter.
86
- //
87
- // In order to support retries, we act as a proxy for stream op batches.
88
- // When we get a batch from the surface, we add it to our list of pending
89
- // batches, and we then use those batches to construct separate "child"
90
- // batches to be started on an LB call. When the child batches return, we
91
- // then decide which pending batches have been completed and schedule their
92
- // callbacks accordingly. If a call attempt fails and we want to retry it,
93
- // we create a new LB call and start again, constructing new "child" batches
94
- // for the new LB call.
95
- //
96
- // Note that retries are committed when receiving data from the server
97
- // (except for Trailers-Only responses). However, there may be many
98
- // send ops started before receiving any data, so we may have already
99
- // completed some number of send ops (and returned the completions up to
100
- // the surface) by the time we realize that we need to retry. To deal
101
- // with this, we cache data for send ops, so that we can replay them on a
102
- // different LB call even after we have completed the original batches.
103
- //
104
- // The code is structured as follows:
105
- // - In CallData (in the parent channel), we maintain a list of pending
106
- // ops and cached data for send ops.
107
- // - There is a CallData::CallAttempt object for each retry attempt.
108
- // This object contains the LB call for that attempt and state to indicate
109
- // which ops from the CallData object have already been sent down to that
110
- // LB call.
111
- // - There is a CallData::CallAttempt::BatchData object for each "child"
112
- // batch sent on the LB call.
113
- //
114
- // When constructing the "child" batches, we compare the state in the
115
- // CallAttempt object against the state in the CallData object to see
116
- // which batches need to be sent on the LB call for a given attempt.
117
-
118
- // TODO(roth): In subsequent PRs:
119
- // - implement hedging
120
-
121
- // By default, we buffer 256 KiB per RPC for retries.
122
- // TODO(roth): Do we have any data to suggest a better value?
123
- #define DEFAULT_PER_RPC_RETRY_BUFFER_SIZE (256 << 10)
124
-
125
- // This value was picked arbitrarily. It can be changed if there is
126
- // any even moderately compelling reason to do so.
127
- #define RETRY_BACKOFF_JITTER 0.2
128
-
129
- namespace grpc_core {
130
-
131
- namespace {
132
-
133
- using internal::RetryGlobalConfig;
134
- using internal::RetryMethodConfig;
135
- using internal::RetryServiceConfigParser;
136
- using internal::ServerRetryThrottleData;
137
-
138
- TraceFlag grpc_retry_trace(false, "retry");
139
-
140
- //
141
- // RetryFilter
142
- //
143
-
144
- class RetryFilter {
145
- public:
146
- class CallData;
147
-
148
- static grpc_error_handle Init(grpc_channel_element* elem,
149
- grpc_channel_element_args* args) {
150
- GPR_ASSERT(args->is_last);
151
- GPR_ASSERT(elem->filter == &kRetryFilterVtable);
152
- grpc_error_handle error = GRPC_ERROR_NONE;
153
- new (elem->channel_data) RetryFilter(args->channel_args, &error);
154
- return error;
155
- }
156
-
157
- static void Destroy(grpc_channel_element* elem) {
158
- auto* chand = static_cast<RetryFilter*>(elem->channel_data);
159
- chand->~RetryFilter();
160
- }
161
-
162
- // Will never be called.
163
- static void StartTransportOp(grpc_channel_element* /*elem*/,
164
- grpc_transport_op* /*op*/) {}
165
- static void GetChannelInfo(grpc_channel_element* /*elem*/,
166
- const grpc_channel_info* /*info*/) {}
167
-
168
- private:
169
- static size_t GetMaxPerRpcRetryBufferSize(const grpc_channel_args* args) {
170
- return static_cast<size_t>(grpc_channel_args_find_integer(
171
- args, GRPC_ARG_PER_RPC_RETRY_BUFFER_SIZE,
172
- {DEFAULT_PER_RPC_RETRY_BUFFER_SIZE, 0, INT_MAX}));
173
- }
174
-
175
- RetryFilter(const grpc_channel_args* args, grpc_error_handle* error)
176
- : client_channel_(grpc_channel_args_find_pointer<ClientChannel>(
177
- args, GRPC_ARG_CLIENT_CHANNEL)),
178
- per_rpc_retry_buffer_size_(GetMaxPerRpcRetryBufferSize(args)),
179
- service_config_parser_index_(
180
- internal::RetryServiceConfigParser::ParserIndex()) {
181
- // Get retry throttling parameters from service config.
182
- auto* service_config = grpc_channel_args_find_pointer<ServiceConfig>(
183
- args, GRPC_ARG_SERVICE_CONFIG_OBJ);
184
- if (service_config == nullptr) return;
185
- const auto* config = static_cast<const RetryGlobalConfig*>(
186
- service_config->GetGlobalParsedConfig(
187
- RetryServiceConfigParser::ParserIndex()));
188
- if (config == nullptr) return;
189
- // Get server name from target URI.
190
- const char* server_uri =
191
- grpc_channel_args_find_string(args, GRPC_ARG_SERVER_URI);
192
- if (server_uri == nullptr) {
193
- *error = GRPC_ERROR_CREATE_FROM_STATIC_STRING(
194
- "server URI channel arg missing or wrong type in client channel "
195
- "filter");
196
- return;
197
- }
198
- absl::StatusOr<URI> uri = URI::Parse(server_uri);
199
- if (!uri.ok() || uri->path().empty()) {
200
- *error = GRPC_ERROR_CREATE_FROM_STATIC_STRING(
201
- "could not extract server name from target URI");
202
- return;
203
- }
204
- std::string server_name(absl::StripPrefix(uri->path(), "/"));
205
- // Get throttling config for server_name.
206
- retry_throttle_data_ =
207
- internal::ServerRetryThrottleMap::Get()->GetDataForServer(
208
- server_name, config->max_milli_tokens(),
209
- config->milli_token_ratio());
210
- }
211
-
212
- const RetryMethodConfig* GetRetryPolicy(
213
- const grpc_call_context_element* context);
214
-
215
- ClientChannel* client_channel_;
216
- size_t per_rpc_retry_buffer_size_;
217
- RefCountedPtr<ServerRetryThrottleData> retry_throttle_data_;
218
- const size_t service_config_parser_index_;
219
- };
220
-
221
- //
222
- // RetryFilter::CallData
223
- //
224
-
225
- class RetryFilter::CallData {
226
- public:
227
- static grpc_error_handle Init(grpc_call_element* elem,
228
- const grpc_call_element_args* args);
229
- static void Destroy(grpc_call_element* elem,
230
- const grpc_call_final_info* /*final_info*/,
231
- grpc_closure* then_schedule_closure);
232
- static void StartTransportStreamOpBatch(
233
- grpc_call_element* elem, grpc_transport_stream_op_batch* batch);
234
- static void SetPollent(grpc_call_element* elem, grpc_polling_entity* pollent);
235
-
236
- private:
237
- class CallStackDestructionBarrier;
238
-
239
- // Pending batches stored in call data.
240
- struct PendingBatch {
241
- // The pending batch. If nullptr, this slot is empty.
242
- grpc_transport_stream_op_batch* batch = nullptr;
243
- // Indicates whether payload for send ops has been cached in CallData.
244
- bool send_ops_cached = false;
245
- };
246
-
247
- // State associated with each call attempt.
248
- class CallAttempt : public RefCounted<CallAttempt> {
249
- public:
250
- CallAttempt(CallData* calld, bool is_transparent_retry);
251
- ~CallAttempt() override;
252
-
253
- bool lb_call_committed() const { return lb_call_committed_; }
254
-
255
- // Constructs and starts whatever batches are needed on this call
256
- // attempt.
257
- void StartRetriableBatches();
258
-
259
- // Frees cached send ops that have already been completed after
260
- // committing the call.
261
- void FreeCachedSendOpDataAfterCommit();
262
-
263
- // Cancels the call attempt.
264
- void CancelFromSurface(grpc_transport_stream_op_batch* cancel_batch);
265
-
266
- private:
267
- // State used for starting a retryable batch on the call attempt's LB call.
268
- // This provides its own grpc_transport_stream_op_batch and other data
269
- // structures needed to populate the ops in the batch.
270
- // We allocate one struct on the arena for each attempt at starting a
271
- // batch on a given LB call.
272
- class BatchData
273
- : public RefCounted<BatchData, PolymorphicRefCount, kUnrefCallDtor> {
274
- public:
275
- BatchData(RefCountedPtr<CallAttempt> call_attempt, int refcount,
276
- bool set_on_complete);
277
- ~BatchData() override;
278
-
279
- grpc_transport_stream_op_batch* batch() { return &batch_; }
280
-
281
- // Adds retriable send_initial_metadata op.
282
- void AddRetriableSendInitialMetadataOp();
283
- // Adds retriable send_message op.
284
- void AddRetriableSendMessageOp();
285
- // Adds retriable send_trailing_metadata op.
286
- void AddRetriableSendTrailingMetadataOp();
287
- // Adds retriable recv_initial_metadata op.
288
- void AddRetriableRecvInitialMetadataOp();
289
- // Adds retriable recv_message op.
290
- void AddRetriableRecvMessageOp();
291
- // Adds retriable recv_trailing_metadata op.
292
- void AddRetriableRecvTrailingMetadataOp();
293
- // Adds cancel_stream op.
294
- void AddCancelStreamOp(grpc_error_handle error);
295
-
296
- private:
297
- // Frees cached send ops that were completed by the completed batch in
298
- // batch_data. Used when batches are completed after the call is
299
- // committed.
300
- void FreeCachedSendOpDataForCompletedBatch();
301
-
302
- // If there is a pending recv_initial_metadata op, adds a closure
303
- // to closures for recv_initial_metadata_ready.
304
- void MaybeAddClosureForRecvInitialMetadataCallback(
305
- grpc_error_handle error, CallCombinerClosureList* closures);
306
- // Intercepts recv_initial_metadata_ready callback for retries.
307
- // Commits the call and returns the initial metadata up the stack.
308
- static void RecvInitialMetadataReady(void* arg, grpc_error_handle error);
309
-
310
- // If there is a pending recv_message op, adds a closure to closures
311
- // for recv_message_ready.
312
- void MaybeAddClosureForRecvMessageCallback(
313
- grpc_error_handle error, CallCombinerClosureList* closures);
314
- // Intercepts recv_message_ready callback for retries.
315
- // Commits the call and returns the message up the stack.
316
- static void RecvMessageReady(void* arg, grpc_error_handle error);
317
-
318
- // If there is a pending recv_trailing_metadata op, adds a closure to
319
- // closures for recv_trailing_metadata_ready.
320
- void MaybeAddClosureForRecvTrailingMetadataReady(
321
- grpc_error_handle error, CallCombinerClosureList* closures);
322
- // Adds any necessary closures for deferred batch completion
323
- // callbacks to closures.
324
- void AddClosuresForDeferredCompletionCallbacks(
325
- CallCombinerClosureList* closures);
326
- // For any pending batch containing an op that has not yet been started,
327
- // adds the pending batch's completion closures to closures.
328
- void AddClosuresToFailUnstartedPendingBatches(
329
- grpc_error_handle error, CallCombinerClosureList* closures);
330
- // Runs necessary closures upon completion of a call attempt.
331
- void RunClosuresForCompletedCall(grpc_error_handle error);
332
- // Intercepts recv_trailing_metadata_ready callback for retries.
333
- // Commits the call and returns the trailing metadata up the stack.
334
- static void RecvTrailingMetadataReady(void* arg, grpc_error_handle error);
335
-
336
- // Adds the on_complete closure for the pending batch completed in
337
- // batch_data to closures.
338
- void AddClosuresForCompletedPendingBatch(
339
- grpc_error_handle error, CallCombinerClosureList* closures);
340
-
341
- // If there are any cached ops to replay or pending ops to start on the
342
- // LB call, adds them to closures.
343
- void AddClosuresForReplayOrPendingSendOps(
344
- CallCombinerClosureList* closures);
345
-
346
- // Callback used to intercept on_complete from LB calls.
347
- static void OnComplete(void* arg, grpc_error_handle error);
348
-
349
- // Callback used to handle on_complete for internally generated
350
- // cancel_stream op.
351
- static void OnCompleteForCancelOp(void* arg, grpc_error_handle error);
352
-
353
- // This DOES hold a ref, but it cannot be a RefCountedPtr<>, because
354
- // our dtor unrefs the owning call, which may delete the arena in
355
- // which we are allocated, which means that running the dtor of any
356
- // data members after that would cause a crash.
357
- CallAttempt* call_attempt_;
358
- // The batch to use in the LB call.
359
- // Its payload field points to CallAttempt::batch_payload_.
360
- grpc_transport_stream_op_batch batch_;
361
- // For intercepting on_complete.
362
- grpc_closure on_complete_;
363
- };
364
-
365
- class AttemptDispatchController
366
- : public ConfigSelector::CallDispatchController {
367
- public:
368
- explicit AttemptDispatchController(CallAttempt* call_attempt)
369
- : call_attempt_(call_attempt) {}
370
-
371
- // Will never be called.
372
- bool ShouldRetry() override { return false; }
373
-
374
- void Commit() override {
375
- call_attempt_->lb_call_committed_ = true;
376
- auto* calld = call_attempt_->calld_;
377
- if (calld->retry_committed_) {
378
- auto* service_config_call_data =
379
- static_cast<ClientChannelServiceConfigCallData*>(
380
- calld->call_context_[GRPC_CONTEXT_SERVICE_CONFIG_CALL_DATA]
381
- .value);
382
- service_config_call_data->call_dispatch_controller()->Commit();
383
- }
384
- }
385
-
386
- private:
387
- CallAttempt* call_attempt_;
388
- };
389
-
390
- // Creates a BatchData object on the call's arena with the
391
- // specified refcount. If set_on_complete is true, the batch's
392
- // on_complete callback will be set to point to on_complete();
393
- // otherwise, the batch's on_complete callback will be null.
394
- BatchData* CreateBatch(int refcount, bool set_on_complete) {
395
- return calld_->arena_->New<BatchData>(Ref(DEBUG_LOCATION, "CreateBatch"),
396
- refcount, set_on_complete);
397
- }
398
-
399
- // If there are any cached send ops that need to be replayed on this
400
- // call attempt, creates and returns a new batch to replay those ops.
401
- // Otherwise, returns nullptr.
402
- BatchData* MaybeCreateBatchForReplay();
403
-
404
- // Adds a closure to closures that will execute batch in the call combiner.
405
- void AddClosureForBatch(grpc_transport_stream_op_batch* batch,
406
- const char* reason,
407
- CallCombinerClosureList* closures);
408
-
409
- // Helper function used to start a recv_trailing_metadata batch. This
410
- // is used in the case where a recv_initial_metadata or recv_message
411
- // op fails in a way that we know the call is over but when the application
412
- // has not yet started its own recv_trailing_metadata op.
413
- void AddBatchForInternalRecvTrailingMetadata(
414
- CallCombinerClosureList* closures);
415
-
416
- // Adds a batch to closures to cancel this call attempt, if
417
- // cancellation has not already been sent on the LB call.
418
- void MaybeAddBatchForCancelOp(grpc_error_handle error,
419
- CallCombinerClosureList* closures);
420
-
421
- // Adds batches for pending batches to closures.
422
- void AddBatchesForPendingBatches(CallCombinerClosureList* closures);
423
-
424
- // Adds whatever batches are needed on this attempt to closures.
425
- void AddRetriableBatches(CallCombinerClosureList* closures);
426
-
427
- // Returns true if any send op in the batch was not yet started on this
428
- // attempt.
429
- bool PendingBatchContainsUnstartedSendOps(PendingBatch* pending);
430
-
431
- // Returns true if there are cached send ops to replay.
432
- bool HaveSendOpsToReplay();
433
-
434
- // If our retry state is no longer needed, switch to fast path by moving
435
- // our LB call into calld_->committed_call_ and having calld_ drop
436
- // its ref to us.
437
- void MaybeSwitchToFastPath();
438
-
439
- // Returns true if the call should be retried.
440
- bool ShouldRetry(absl::optional<grpc_status_code> status,
441
- absl::optional<Duration> server_pushback_ms);
442
-
443
- // Abandons the call attempt. Unrefs any deferred batches.
444
- void Abandon();
445
-
446
- static void OnPerAttemptRecvTimer(void* arg, grpc_error_handle error);
447
- static void OnPerAttemptRecvTimerLocked(void* arg, grpc_error_handle error);
448
- void MaybeCancelPerAttemptRecvTimer();
449
-
450
- CallData* calld_;
451
- AttemptDispatchController attempt_dispatch_controller_;
452
- OrphanablePtr<ClientChannel::LoadBalancedCall> lb_call_;
453
- bool lb_call_committed_ = false;
454
-
455
- grpc_timer per_attempt_recv_timer_;
456
- grpc_closure on_per_attempt_recv_timer_;
457
- bool per_attempt_recv_timer_pending_ = false;
458
-
459
- // BatchData.batch.payload points to this.
460
- grpc_transport_stream_op_batch_payload batch_payload_;
461
- // For send_initial_metadata.
462
- grpc_metadata_batch send_initial_metadata_{calld_->arena_};
463
- // For send_trailing_metadata.
464
- grpc_metadata_batch send_trailing_metadata_{calld_->arena_};
465
- // For intercepting recv_initial_metadata.
466
- grpc_metadata_batch recv_initial_metadata_{calld_->arena_};
467
- grpc_closure recv_initial_metadata_ready_;
468
- bool trailing_metadata_available_ = false;
469
- // For intercepting recv_message.
470
- grpc_closure recv_message_ready_;
471
- absl::optional<SliceBuffer> recv_message_;
472
- uint32_t recv_message_flags_;
473
- // For intercepting recv_trailing_metadata.
474
- grpc_metadata_batch recv_trailing_metadata_{calld_->arena_};
475
- grpc_transport_stream_stats collect_stats_;
476
- grpc_closure recv_trailing_metadata_ready_;
477
- // These fields indicate which ops have been started and completed on
478
- // this call attempt.
479
- size_t started_send_message_count_ = 0;
480
- size_t completed_send_message_count_ = 0;
481
- size_t started_recv_message_count_ = 0;
482
- size_t completed_recv_message_count_ = 0;
483
- bool started_send_initial_metadata_ : 1;
484
- bool completed_send_initial_metadata_ : 1;
485
- bool started_send_trailing_metadata_ : 1;
486
- bool completed_send_trailing_metadata_ : 1;
487
- bool started_recv_initial_metadata_ : 1;
488
- bool completed_recv_initial_metadata_ : 1;
489
- bool started_recv_trailing_metadata_ : 1;
490
- bool completed_recv_trailing_metadata_ : 1;
491
- bool sent_cancel_stream_ : 1;
492
- // State for callback processing.
493
- RefCountedPtr<BatchData> recv_initial_metadata_ready_deferred_batch_;
494
- grpc_error_handle recv_initial_metadata_error_ = GRPC_ERROR_NONE;
495
- RefCountedPtr<BatchData> recv_message_ready_deferred_batch_;
496
- grpc_error_handle recv_message_error_ = GRPC_ERROR_NONE;
497
- struct OnCompleteDeferredBatch {
498
- OnCompleteDeferredBatch(RefCountedPtr<BatchData> batch,
499
- grpc_error_handle error)
500
- : batch(std::move(batch)), error(error) {}
501
- RefCountedPtr<BatchData> batch;
502
- grpc_error_handle error;
503
- };
504
- // There cannot be more than 3 pending send op batches at a time.
505
- absl::InlinedVector<OnCompleteDeferredBatch, 3>
506
- on_complete_deferred_batches_;
507
- RefCountedPtr<BatchData> recv_trailing_metadata_internal_batch_;
508
- grpc_error_handle recv_trailing_metadata_error_ = GRPC_ERROR_NONE;
509
- bool seen_recv_trailing_metadata_from_surface_ : 1;
510
- // NOTE: Do not move this next to the metadata bitfields above. That would
511
- // save space but will also result in a data race because compiler
512
- // will generate a 2 byte store which overwrites the meta-data
513
- // fields upon setting this field.
514
- bool abandoned_ : 1;
515
- };
516
-
517
- CallData(RetryFilter* chand, const grpc_call_element_args& args);
518
- ~CallData();
519
-
520
- void StartTransportStreamOpBatch(grpc_transport_stream_op_batch* batch);
521
-
522
- // Returns the index into pending_batches_ to be used for batch.
523
- static size_t GetBatchIndex(grpc_transport_stream_op_batch* batch);
524
- PendingBatch* PendingBatchesAdd(grpc_transport_stream_op_batch* batch);
525
- void PendingBatchClear(PendingBatch* pending);
526
- void MaybeClearPendingBatch(PendingBatch* pending);
527
- static void FailPendingBatchInCallCombiner(void* arg,
528
- grpc_error_handle error);
529
- // Fails all pending batches. Does NOT yield call combiner.
530
- void PendingBatchesFail(grpc_error_handle error);
531
- // Returns a pointer to the first pending batch for which predicate(batch)
532
- // returns true, or null if not found.
533
- template <typename Predicate>
534
- PendingBatch* PendingBatchFind(const char* log_message, Predicate predicate);
535
-
536
- // Caches data for send ops so that it can be retried later, if not
537
- // already cached.
538
- void MaybeCacheSendOpsForBatch(PendingBatch* pending);
539
- void FreeCachedSendInitialMetadata();
540
- // Frees cached send_message at index idx.
541
- void FreeCachedSendMessage(size_t idx);
542
- void FreeCachedSendTrailingMetadata();
543
- void FreeAllCachedSendOpData();
544
-
545
- // Commits the call so that no further retry attempts will be performed.
546
- void RetryCommit(CallAttempt* call_attempt);
547
-
548
- // Starts a timer to retry after appropriate back-off.
549
- // If server_pushback is nullopt, retry_backoff_ is used.
550
- void StartRetryTimer(absl::optional<Duration> server_pushback);
551
-
552
- static void OnRetryTimer(void* arg, grpc_error_handle error);
553
- static void OnRetryTimerLocked(void* arg, grpc_error_handle error);
554
-
555
- // Adds a closure to closures to start a transparent retry.
556
- void AddClosureToStartTransparentRetry(CallCombinerClosureList* closures);
557
- static void StartTransparentRetry(void* arg, grpc_error_handle error);
558
-
559
- OrphanablePtr<ClientChannel::LoadBalancedCall> CreateLoadBalancedCall(
560
- ConfigSelector::CallDispatchController* call_dispatch_controller,
561
- bool is_transparent_retry);
562
-
563
- void CreateCallAttempt(bool is_transparent_retry);
564
-
565
- RetryFilter* chand_;
566
- grpc_polling_entity* pollent_;
567
- RefCountedPtr<ServerRetryThrottleData> retry_throttle_data_;
568
- const RetryMethodConfig* retry_policy_ = nullptr;
569
- BackOff retry_backoff_;
570
-
571
- grpc_slice path_; // Request path.
572
- Timestamp deadline_;
573
- Arena* arena_;
574
- grpc_call_stack* owning_call_;
575
- CallCombiner* call_combiner_;
576
- grpc_call_context_element* call_context_;
577
-
578
- grpc_error_handle cancelled_from_surface_ = GRPC_ERROR_NONE;
579
-
580
- RefCountedPtr<CallStackDestructionBarrier> call_stack_destruction_barrier_;
581
-
582
- // TODO(roth): As part of implementing hedging, we will need to maintain a
583
- // list of all pending attempts, so that we can cancel them all if the call
584
- // gets cancelled.
585
- RefCountedPtr<CallAttempt> call_attempt_;
586
-
587
- // LB call used when we've committed to a call attempt and the retry
588
- // state for that attempt is no longer needed. This provides a fast
589
- // path for long-running streaming calls that minimizes overhead.
590
- OrphanablePtr<ClientChannel::LoadBalancedCall> committed_call_;
591
-
592
- // When are are not yet fully committed to a particular call (i.e.,
593
- // either we might still retry or we have committed to the call but
594
- // there are still some cached ops to be replayed on the call),
595
- // batches received from above will be added to this list, and they
596
- // will not be removed until we have invoked their completion callbacks.
597
- size_t bytes_buffered_for_retry_ = 0;
598
- PendingBatch pending_batches_[MAX_PENDING_BATCHES];
599
- bool pending_send_initial_metadata_ : 1;
600
- bool pending_send_message_ : 1;
601
- bool pending_send_trailing_metadata_ : 1;
602
-
603
- // Retry state.
604
- bool retry_committed_ : 1;
605
- bool retry_timer_pending_ : 1;
606
- bool retry_codepath_started_ : 1;
607
- bool sent_transparent_retry_not_seen_by_server_ : 1;
608
- int num_attempts_completed_ = 0;
609
- grpc_timer retry_timer_;
610
- grpc_closure retry_closure_;
611
-
612
- // Cached data for retrying send ops.
613
- // send_initial_metadata
614
- bool seen_send_initial_metadata_ = false;
615
- grpc_metadata_batch send_initial_metadata_{arena_};
616
- // TODO(roth): As part of implementing hedging, we'll probably need to
617
- // have the LB call set a value in CallAttempt and then propagate it
618
- // from CallAttempt to the parent call when we commit. Otherwise, we
619
- // may leave this with a value for a peer other than the one we
620
- // actually commit to. Alternatively, maybe see if there's a way to
621
- // change the surface API such that the peer isn't available until
622
- // after initial metadata is received? (Could even change the
623
- // transport API to return this with the recv_initial_metadata op.)
624
- gpr_atm* peer_string_;
625
- // send_message
626
- // When we get a send_message op, we replace the original byte stream
627
- // with a CachingByteStream that caches the slices to a local buffer for
628
- // use in retries.
629
- // Note: We inline the cache for the first 3 send_message ops and use
630
- // dynamic allocation after that. This number was essentially picked
631
- // at random; it could be changed in the future to tune performance.
632
- struct CachedSendMessage {
633
- SliceBuffer* slices;
634
- uint32_t flags;
635
- };
636
- absl::InlinedVector<CachedSendMessage, 3> send_messages_;
637
- // send_trailing_metadata
638
- bool seen_send_trailing_metadata_ = false;
639
- grpc_metadata_batch send_trailing_metadata_{arena_};
640
- };
641
-
642
- //
643
- // RetryFilter::CallData::CallStackDestructionBarrier
644
- //
645
-
646
- // A class to track the existence of LoadBalancedCall call stacks that
647
- // we've created. We wait until all such call stacks have been
648
- // destroyed before we return the on_call_stack_destruction closure up
649
- // to the surface.
650
- //
651
- // The parent RetryFilter::CallData object holds a ref to this object.
652
- // When it is destroyed, it will store the on_call_stack_destruction
653
- // closure from the surface in this object and then release its ref.
654
- // We also take a ref to this object for each LB call we create, and
655
- // those refs are not released until the LB call stack is destroyed.
656
- // When this object is destroyed, it will invoke the
657
- // on_call_stack_destruction closure from the surface.
658
- class RetryFilter::CallData::CallStackDestructionBarrier
659
- : public RefCounted<CallStackDestructionBarrier, PolymorphicRefCount,
660
- kUnrefCallDtor> {
661
- public:
662
- CallStackDestructionBarrier() {}
663
-
664
- ~CallStackDestructionBarrier() override {
665
- // TODO(yashkt) : This can potentially be a Closure::Run
666
- ExecCtx::Run(DEBUG_LOCATION, on_call_stack_destruction_, GRPC_ERROR_NONE);
667
- }
668
-
669
- // Set the closure from the surface. This closure will be invoked
670
- // when this object is destroyed.
671
- void set_on_call_stack_destruction(grpc_closure* on_call_stack_destruction) {
672
- on_call_stack_destruction_ = on_call_stack_destruction;
673
- }
674
-
675
- // Invoked to get an on_call_stack_destruction closure for a new LB call.
676
- grpc_closure* MakeLbCallDestructionClosure(CallData* calld) {
677
- Ref().release(); // Ref held by callback.
678
- grpc_closure* on_lb_call_destruction_complete =
679
- calld->arena_->New<grpc_closure>();
680
- GRPC_CLOSURE_INIT(on_lb_call_destruction_complete,
681
- OnLbCallDestructionComplete, this, nullptr);
682
- return on_lb_call_destruction_complete;
683
- }
684
-
685
- private:
686
- static void OnLbCallDestructionComplete(void* arg,
687
- grpc_error_handle /*error*/) {
688
- auto* self = static_cast<CallStackDestructionBarrier*>(arg);
689
- self->Unref();
690
- }
691
-
692
- grpc_closure* on_call_stack_destruction_ = nullptr;
693
- };
694
-
695
- //
696
- // RetryFilter::CallData::CallAttempt
697
- //
698
-
699
- RetryFilter::CallData::CallAttempt::CallAttempt(CallData* calld,
700
- bool is_transparent_retry)
701
- : RefCounted(GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace) ? "CallAttempt"
702
- : nullptr),
703
- calld_(calld),
704
- attempt_dispatch_controller_(this),
705
- batch_payload_(calld->call_context_),
706
- started_send_initial_metadata_(false),
707
- completed_send_initial_metadata_(false),
708
- started_send_trailing_metadata_(false),
709
- completed_send_trailing_metadata_(false),
710
- started_recv_initial_metadata_(false),
711
- completed_recv_initial_metadata_(false),
712
- started_recv_trailing_metadata_(false),
713
- completed_recv_trailing_metadata_(false),
714
- sent_cancel_stream_(false),
715
- seen_recv_trailing_metadata_from_surface_(false),
716
- abandoned_(false) {
717
- lb_call_ = calld->CreateLoadBalancedCall(&attempt_dispatch_controller_,
718
- is_transparent_retry);
719
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
720
- gpr_log(GPR_INFO,
721
- "chand=%p calld=%p attempt=%p: created attempt, lb_call=%p",
722
- calld->chand_, calld, this, lb_call_.get());
723
- }
724
- // If per_attempt_recv_timeout is set, start a timer.
725
- if (calld->retry_policy_ != nullptr &&
726
- calld->retry_policy_->per_attempt_recv_timeout().has_value()) {
727
- Timestamp per_attempt_recv_deadline =
728
- Timestamp::Now() + *calld->retry_policy_->per_attempt_recv_timeout();
729
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
730
- gpr_log(GPR_INFO,
731
- "chand=%p calld=%p attempt=%p: per-attempt timeout in %" PRId64
732
- " ms",
733
- calld->chand_, calld, this,
734
- calld->retry_policy_->per_attempt_recv_timeout()->millis());
735
- }
736
- // Schedule retry after computed delay.
737
- GRPC_CLOSURE_INIT(&on_per_attempt_recv_timer_, OnPerAttemptRecvTimer, this,
738
- nullptr);
739
- GRPC_CALL_STACK_REF(calld->owning_call_, "OnPerAttemptRecvTimer");
740
- Ref(DEBUG_LOCATION, "OnPerAttemptRecvTimer").release();
741
- per_attempt_recv_timer_pending_ = true;
742
- grpc_timer_init(&per_attempt_recv_timer_, per_attempt_recv_deadline,
743
- &on_per_attempt_recv_timer_);
744
- }
745
- }
746
-
747
- RetryFilter::CallData::CallAttempt::~CallAttempt() {
748
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
749
- gpr_log(GPR_INFO, "chand=%p calld=%p attempt=%p: destroying call attempt",
750
- calld_->chand_, calld_, this);
751
- }
752
- }
753
-
754
- void RetryFilter::CallData::CallAttempt::FreeCachedSendOpDataAfterCommit() {
755
- // TODO(roth): When we implement hedging, this logic will need to get
756
- // a bit more complex, because there may be other (now abandoned) call
757
- // attempts still using this data. We may need to do some sort of
758
- // ref-counting instead.
759
- if (completed_send_initial_metadata_) {
760
- calld_->FreeCachedSendInitialMetadata();
761
- }
762
- for (size_t i = 0; i < completed_send_message_count_; ++i) {
763
- calld_->FreeCachedSendMessage(i);
764
- }
765
- if (completed_send_trailing_metadata_) {
766
- calld_->FreeCachedSendTrailingMetadata();
767
- }
768
- }
769
-
770
- bool RetryFilter::CallData::CallAttempt::PendingBatchContainsUnstartedSendOps(
771
- PendingBatch* pending) {
772
- if (pending->batch->on_complete == nullptr) return false;
773
- if (pending->batch->send_initial_metadata &&
774
- !started_send_initial_metadata_) {
775
- return true;
776
- }
777
- if (pending->batch->send_message &&
778
- started_send_message_count_ < calld_->send_messages_.size()) {
779
- return true;
780
- }
781
- if (pending->batch->send_trailing_metadata &&
782
- !started_send_trailing_metadata_) {
783
- return true;
784
- }
785
- return false;
786
- }
787
-
788
- bool RetryFilter::CallData::CallAttempt::HaveSendOpsToReplay() {
789
- // We don't check send_initial_metadata here, because that op will always
790
- // be started as soon as it is received from the surface, so it will
791
- // never need to be started at this point.
792
- return started_send_message_count_ < calld_->send_messages_.size() ||
793
- (calld_->seen_send_trailing_metadata_ &&
794
- !started_send_trailing_metadata_);
795
- }
796
-
797
- void RetryFilter::CallData::CallAttempt::MaybeSwitchToFastPath() {
798
- // If we're not yet committed, we can't switch yet.
799
- // TODO(roth): As part of implementing hedging, this logic needs to
800
- // check that *this* call attempt is the one that we've committed to.
801
- // Might need to replace abandoned_ with an enum indicating whether we're
802
- // in flight, abandoned, or the winning call attempt.
803
- if (!calld_->retry_committed_) return;
804
- // If we've already switched to fast path, there's nothing to do here.
805
- if (calld_->committed_call_ != nullptr) return;
806
- // If the perAttemptRecvTimeout timer is pending, we can't switch yet.
807
- if (per_attempt_recv_timer_pending_) return;
808
- // If there are still send ops to replay, we can't switch yet.
809
- if (HaveSendOpsToReplay()) return;
810
- // If we started an internal batch for recv_trailing_metadata but have not
811
- // yet seen that op from the surface, we can't switch yet.
812
- if (recv_trailing_metadata_internal_batch_ != nullptr) return;
813
- // Switch to fast path.
814
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
815
- gpr_log(GPR_INFO,
816
- "chand=%p calld=%p attempt=%p: retry state no longer needed; "
817
- "moving LB call to parent and unreffing the call attempt",
818
- calld_->chand_, calld_, this);
819
- }
820
- calld_->committed_call_ = std::move(lb_call_);
821
- calld_->call_attempt_.reset(DEBUG_LOCATION, "MaybeSwitchToFastPath");
822
- }
823
-
824
- // If there are any cached send ops that need to be replayed on the
825
- // current call attempt, creates and returns a new batch to replay those ops.
826
- // Otherwise, returns nullptr.
827
- RetryFilter::CallData::CallAttempt::BatchData*
828
- RetryFilter::CallData::CallAttempt::MaybeCreateBatchForReplay() {
829
- BatchData* replay_batch_data = nullptr;
830
- // send_initial_metadata.
831
- if (calld_->seen_send_initial_metadata_ && !started_send_initial_metadata_ &&
832
- !calld_->pending_send_initial_metadata_) {
833
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
834
- gpr_log(GPR_INFO,
835
- "chand=%p calld=%p attempt=%p: replaying previously completed "
836
- "send_initial_metadata op",
837
- calld_->chand_, calld_, this);
838
- }
839
- replay_batch_data = CreateBatch(1, true /* set_on_complete */);
840
- replay_batch_data->AddRetriableSendInitialMetadataOp();
841
- }
842
- // send_message.
843
- // Note that we can only have one send_message op in flight at a time.
844
- if (started_send_message_count_ < calld_->send_messages_.size() &&
845
- started_send_message_count_ == completed_send_message_count_ &&
846
- !calld_->pending_send_message_) {
847
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
848
- gpr_log(GPR_INFO,
849
- "chand=%p calld=%p attempt=%p: replaying previously completed "
850
- "send_message op",
851
- calld_->chand_, calld_, this);
852
- }
853
- if (replay_batch_data == nullptr) {
854
- replay_batch_data = CreateBatch(1, true /* set_on_complete */);
855
- }
856
- replay_batch_data->AddRetriableSendMessageOp();
857
- }
858
- // send_trailing_metadata.
859
- // Note that we only add this op if we have no more send_message ops
860
- // to start, since we can't send down any more send_message ops after
861
- // send_trailing_metadata.
862
- if (calld_->seen_send_trailing_metadata_ &&
863
- started_send_message_count_ == calld_->send_messages_.size() &&
864
- !started_send_trailing_metadata_ &&
865
- !calld_->pending_send_trailing_metadata_) {
866
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
867
- gpr_log(GPR_INFO,
868
- "chand=%p calld=%p attempt=%p: replaying previously completed "
869
- "send_trailing_metadata op",
870
- calld_->chand_, calld_, this);
871
- }
872
- if (replay_batch_data == nullptr) {
873
- replay_batch_data = CreateBatch(1, true /* set_on_complete */);
874
- }
875
- replay_batch_data->AddRetriableSendTrailingMetadataOp();
876
- }
877
- return replay_batch_data;
878
- }
879
-
880
- namespace {
881
-
882
- void StartBatchInCallCombiner(void* arg, grpc_error_handle /*ignored*/) {
883
- grpc_transport_stream_op_batch* batch =
884
- static_cast<grpc_transport_stream_op_batch*>(arg);
885
- auto* lb_call = static_cast<ClientChannel::LoadBalancedCall*>(
886
- batch->handler_private.extra_arg);
887
- // Note: This will release the call combiner.
888
- lb_call->StartTransportStreamOpBatch(batch);
889
- }
890
-
891
- } // namespace
892
-
893
- void RetryFilter::CallData::CallAttempt::AddClosureForBatch(
894
- grpc_transport_stream_op_batch* batch, const char* reason,
895
- CallCombinerClosureList* closures) {
896
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
897
- gpr_log(GPR_INFO, "chand=%p calld=%p attempt=%p: adding batch (%s): %s",
898
- calld_->chand_, calld_, this, reason,
899
- grpc_transport_stream_op_batch_string(batch).c_str());
900
- }
901
- batch->handler_private.extra_arg = lb_call_.get();
902
- GRPC_CLOSURE_INIT(&batch->handler_private.closure, StartBatchInCallCombiner,
903
- batch, grpc_schedule_on_exec_ctx);
904
- closures->Add(&batch->handler_private.closure, GRPC_ERROR_NONE, reason);
905
- }
906
-
907
- void RetryFilter::CallData::CallAttempt::
908
- AddBatchForInternalRecvTrailingMetadata(CallCombinerClosureList* closures) {
909
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
910
- gpr_log(GPR_INFO,
911
- "chand=%p calld=%p attempt=%p: call failed but "
912
- "recv_trailing_metadata not started; starting it internally",
913
- calld_->chand_, calld_, this);
914
- }
915
- // Create batch_data with 2 refs, since this batch will be unreffed twice:
916
- // once for the recv_trailing_metadata_ready callback when the batch
917
- // completes, and again when we actually get a recv_trailing_metadata
918
- // op from the surface.
919
- BatchData* batch_data = CreateBatch(2, false /* set_on_complete */);
920
- batch_data->AddRetriableRecvTrailingMetadataOp();
921
- recv_trailing_metadata_internal_batch_.reset(batch_data);
922
- AddClosureForBatch(batch_data->batch(),
923
- "starting internal recv_trailing_metadata", closures);
924
- }
925
-
926
- void RetryFilter::CallData::CallAttempt::MaybeAddBatchForCancelOp(
927
- grpc_error_handle error, CallCombinerClosureList* closures) {
928
- if (sent_cancel_stream_) {
929
- GRPC_ERROR_UNREF(error);
930
- return;
931
- }
932
- sent_cancel_stream_ = true;
933
- BatchData* cancel_batch_data = CreateBatch(1, /*set_on_complete=*/true);
934
- cancel_batch_data->AddCancelStreamOp(error);
935
- AddClosureForBatch(cancel_batch_data->batch(),
936
- "start cancellation batch on call attempt", closures);
937
- }
938
-
939
- void RetryFilter::CallData::CallAttempt::AddBatchesForPendingBatches(
940
- CallCombinerClosureList* closures) {
941
- for (size_t i = 0; i < GPR_ARRAY_SIZE(calld_->pending_batches_); ++i) {
942
- PendingBatch* pending = &calld_->pending_batches_[i];
943
- grpc_transport_stream_op_batch* batch = pending->batch;
944
- if (batch == nullptr) continue;
945
- bool has_send_ops = false;
946
- // Skip any batch that either (a) has already been started on this
947
- // call attempt or (b) we can't start yet because we're still
948
- // replaying send ops that need to be completed first.
949
- // TODO(roth): Note that if any one op in the batch can't be sent
950
- // yet due to ops that we're replaying, we don't start any of the ops
951
- // in the batch. This is probably okay, but it could conceivably
952
- // lead to increased latency in some cases -- e.g., we could delay
953
- // starting a recv op due to it being in the same batch with a send
954
- // op. If/when we revamp the callback protocol in
955
- // transport_stream_op_batch, we may be able to fix this.
956
- if (batch->send_initial_metadata) {
957
- if (started_send_initial_metadata_) continue;
958
- has_send_ops = true;
959
- }
960
- if (batch->send_message) {
961
- // Cases where we can't start this send_message op:
962
- // - We are currently replaying a previous cached send_message op.
963
- // - We have already replayed all send_message ops, including this
964
- // one. (This can happen if a send_message op is in the same
965
- // batch as a recv op, the send_message op has already completed
966
- // but the recv op hasn't, and then a subsequent batch with another
967
- // recv op is started from the surface.)
968
- if (completed_send_message_count_ < started_send_message_count_ ||
969
- completed_send_message_count_ ==
970
- (calld_->send_messages_.size() + !pending->send_ops_cached)) {
971
- continue;
972
- }
973
- has_send_ops = true;
974
- }
975
- // Note that we only start send_trailing_metadata if we have no more
976
- // send_message ops to start, since we can't send down any more
977
- // send_message ops after send_trailing_metadata.
978
- if (batch->send_trailing_metadata) {
979
- if (started_send_message_count_ + batch->send_message <
980
- calld_->send_messages_.size() ||
981
- started_send_trailing_metadata_) {
982
- continue;
983
- }
984
- has_send_ops = true;
985
- }
986
- int num_callbacks = has_send_ops; // All send ops share one callback.
987
- if (batch->recv_initial_metadata) {
988
- if (started_recv_initial_metadata_) continue;
989
- ++num_callbacks;
990
- }
991
- if (batch->recv_message) {
992
- // Skip if the op is already in flight, or if it has already completed
993
- // but the completion has not yet been sent to the surface.
994
- if (completed_recv_message_count_ < started_recv_message_count_ ||
995
- recv_message_ready_deferred_batch_ != nullptr) {
996
- continue;
997
- }
998
- ++num_callbacks;
999
- }
1000
- if (batch->recv_trailing_metadata) {
1001
- if (started_recv_trailing_metadata_) {
1002
- seen_recv_trailing_metadata_from_surface_ = true;
1003
- // If we previously completed a recv_trailing_metadata op
1004
- // initiated by AddBatchForInternalRecvTrailingMetadata(), use the
1005
- // result of that instead of trying to re-start this op.
1006
- if (GPR_UNLIKELY(recv_trailing_metadata_internal_batch_ != nullptr)) {
1007
- // If the batch completed, then trigger the completion callback
1008
- // directly, so that we return the previously returned results to
1009
- // the application. Otherwise, just unref the internally started
1010
- // batch, since we'll propagate the completion when it completes.
1011
- if (completed_recv_trailing_metadata_) {
1012
- closures->Add(
1013
- &recv_trailing_metadata_ready_, recv_trailing_metadata_error_,
1014
- "re-executing recv_trailing_metadata_ready to propagate "
1015
- "internally triggered result");
1016
- // Ref will be released by callback.
1017
- recv_trailing_metadata_internal_batch_.release();
1018
- } else {
1019
- recv_trailing_metadata_internal_batch_.reset(
1020
- DEBUG_LOCATION,
1021
- "internally started recv_trailing_metadata batch pending and "
1022
- "recv_trailing_metadata started from surface");
1023
- GRPC_ERROR_UNREF(recv_trailing_metadata_error_);
1024
- }
1025
- recv_trailing_metadata_error_ = GRPC_ERROR_NONE;
1026
- }
1027
- // We don't want the fact that we've already started this op internally
1028
- // to prevent us from adding a batch that may contain other ops.
1029
- // Instead, we'll just skip adding this op below.
1030
- if (num_callbacks == 0) continue;
1031
- } else {
1032
- ++num_callbacks;
1033
- }
1034
- }
1035
- // If we're already committed and the following conditions are met,
1036
- // just send the batch down as-is:
1037
- // - The batch contains no cached send ops. (If it does, we need
1038
- // the logic below to use the cached payloads.)
1039
- // - The batch does not contain recv_trailing_metadata when we have
1040
- // already started an internal recv_trailing_metadata batch. (If
1041
- // we've already started an internal recv_trailing_metadata batch,
1042
- // then we need the logic below to send all ops in the batch
1043
- // *except* the recv_trailing_metadata op.)
1044
- if (calld_->retry_committed_ && !pending->send_ops_cached &&
1045
- (!batch->recv_trailing_metadata || !started_recv_trailing_metadata_)) {
1046
- AddClosureForBatch(
1047
- batch,
1048
- "start non-replayable pending batch on call attempt after commit",
1049
- closures);
1050
- calld_->PendingBatchClear(pending);
1051
- continue;
1052
- }
1053
- // Create batch with the right number of callbacks.
1054
- BatchData* batch_data =
1055
- CreateBatch(num_callbacks, has_send_ops /* set_on_complete */);
1056
- // Cache send ops if needed.
1057
- calld_->MaybeCacheSendOpsForBatch(pending);
1058
- // send_initial_metadata.
1059
- if (batch->send_initial_metadata) {
1060
- batch_data->AddRetriableSendInitialMetadataOp();
1061
- }
1062
- // send_message.
1063
- if (batch->send_message) {
1064
- batch_data->AddRetriableSendMessageOp();
1065
- }
1066
- // send_trailing_metadata.
1067
- if (batch->send_trailing_metadata) {
1068
- batch_data->AddRetriableSendTrailingMetadataOp();
1069
- }
1070
- // recv_initial_metadata.
1071
- if (batch->recv_initial_metadata) {
1072
- batch_data->AddRetriableRecvInitialMetadataOp();
1073
- }
1074
- // recv_message.
1075
- if (batch->recv_message) {
1076
- batch_data->AddRetriableRecvMessageOp();
1077
- }
1078
- // recv_trailing_metadata.
1079
- if (batch->recv_trailing_metadata && !started_recv_trailing_metadata_) {
1080
- batch_data->AddRetriableRecvTrailingMetadataOp();
1081
- }
1082
- AddClosureForBatch(batch_data->batch(),
1083
- "start replayable pending batch on call attempt",
1084
- closures);
1085
- }
1086
- }
1087
-
1088
- void RetryFilter::CallData::CallAttempt::AddRetriableBatches(
1089
- CallCombinerClosureList* closures) {
1090
- // Replay previously-returned send_* ops if needed.
1091
- BatchData* replay_batch_data = MaybeCreateBatchForReplay();
1092
- if (replay_batch_data != nullptr) {
1093
- AddClosureForBatch(replay_batch_data->batch(),
1094
- "start replay batch on call attempt", closures);
1095
- }
1096
- // Now add pending batches.
1097
- AddBatchesForPendingBatches(closures);
1098
- }
1099
-
1100
- void RetryFilter::CallData::CallAttempt::StartRetriableBatches() {
1101
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1102
- gpr_log(GPR_INFO,
1103
- "chand=%p calld=%p attempt=%p: constructing retriable batches",
1104
- calld_->chand_, calld_, this);
1105
- }
1106
- // Construct list of closures to execute, one for each pending batch.
1107
- CallCombinerClosureList closures;
1108
- AddRetriableBatches(&closures);
1109
- // Note: This will yield the call combiner.
1110
- // Start batches on LB call.
1111
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1112
- gpr_log(GPR_INFO,
1113
- "chand=%p calld=%p attempt=%p: starting %" PRIuPTR
1114
- " retriable batches on lb_call=%p",
1115
- calld_->chand_, calld_, this, closures.size(), lb_call_.get());
1116
- }
1117
- closures.RunClosures(calld_->call_combiner_);
1118
- }
1119
-
1120
- void RetryFilter::CallData::CallAttempt::CancelFromSurface(
1121
- grpc_transport_stream_op_batch* cancel_batch) {
1122
- MaybeCancelPerAttemptRecvTimer();
1123
- Abandon();
1124
- // Propagate cancellation to LB call.
1125
- lb_call_->StartTransportStreamOpBatch(cancel_batch);
1126
- }
1127
-
1128
- bool RetryFilter::CallData::CallAttempt::ShouldRetry(
1129
- absl::optional<grpc_status_code> status,
1130
- absl::optional<Duration> server_pushback) {
1131
- // If no retry policy, don't retry.
1132
- if (calld_->retry_policy_ == nullptr) return false;
1133
- // Check status.
1134
- if (status.has_value()) {
1135
- if (GPR_LIKELY(*status == GRPC_STATUS_OK)) {
1136
- if (calld_->retry_throttle_data_ != nullptr) {
1137
- calld_->retry_throttle_data_->RecordSuccess();
1138
- }
1139
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1140
- gpr_log(GPR_INFO, "chand=%p calld=%p attempt=%p: call succeeded",
1141
- calld_->chand_, calld_, this);
1142
- }
1143
- return false;
1144
- }
1145
- // Status is not OK. Check whether the status is retryable.
1146
- if (!calld_->retry_policy_->retryable_status_codes().Contains(*status)) {
1147
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1148
- gpr_log(GPR_INFO,
1149
- "chand=%p calld=%p attempt=%p: status %s not configured as "
1150
- "retryable",
1151
- calld_->chand_, calld_, this,
1152
- grpc_status_code_to_string(*status));
1153
- }
1154
- return false;
1155
- }
1156
- }
1157
- // Record the failure and check whether retries are throttled.
1158
- // Note that it's important for this check to come after the status
1159
- // code check above, since we should only record failures whose statuses
1160
- // match the configured retryable status codes, so that we don't count
1161
- // things like failures due to malformed requests (INVALID_ARGUMENT).
1162
- // Conversely, it's important for this to come before the remaining
1163
- // checks, so that we don't fail to record failures due to other factors.
1164
- if (calld_->retry_throttle_data_ != nullptr &&
1165
- !calld_->retry_throttle_data_->RecordFailure()) {
1166
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1167
- gpr_log(GPR_INFO, "chand=%p calld=%p attempt=%p: retries throttled",
1168
- calld_->chand_, calld_, this);
1169
- }
1170
- return false;
1171
- }
1172
- // Check whether the call is committed.
1173
- if (calld_->retry_committed_) {
1174
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1175
- gpr_log(GPR_INFO,
1176
- "chand=%p calld=%p attempt=%p: retries already committed",
1177
- calld_->chand_, calld_, this);
1178
- }
1179
- return false;
1180
- }
1181
- // Check whether we have retries remaining.
1182
- ++calld_->num_attempts_completed_;
1183
- if (calld_->num_attempts_completed_ >=
1184
- calld_->retry_policy_->max_attempts()) {
1185
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1186
- gpr_log(
1187
- GPR_INFO, "chand=%p calld=%p attempt=%p: exceeded %d retry attempts",
1188
- calld_->chand_, calld_, this, calld_->retry_policy_->max_attempts());
1189
- }
1190
- return false;
1191
- }
1192
- // Check server push-back.
1193
- if (server_pushback.has_value()) {
1194
- if (*server_pushback < Duration::Zero()) {
1195
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1196
- gpr_log(GPR_INFO,
1197
- "chand=%p calld=%p attempt=%p: not retrying due to server "
1198
- "push-back",
1199
- calld_->chand_, calld_, this);
1200
- }
1201
- return false;
1202
- } else {
1203
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1204
- gpr_log(
1205
- GPR_INFO,
1206
- "chand=%p calld=%p attempt=%p: server push-back: retry in %" PRIu64
1207
- " ms",
1208
- calld_->chand_, calld_, this, server_pushback->millis());
1209
- }
1210
- }
1211
- }
1212
- // Check with call dispatch controller.
1213
- auto* service_config_call_data =
1214
- static_cast<ClientChannelServiceConfigCallData*>(
1215
- calld_->call_context_[GRPC_CONTEXT_SERVICE_CONFIG_CALL_DATA].value);
1216
- if (!service_config_call_data->call_dispatch_controller()->ShouldRetry()) {
1217
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1218
- gpr_log(
1219
- GPR_INFO,
1220
- "chand=%p calld=%p attempt=%p: call dispatch controller denied retry",
1221
- calld_->chand_, calld_, this);
1222
- }
1223
- return false;
1224
- }
1225
- // We should retry.
1226
- return true;
1227
- }
1228
-
1229
- void RetryFilter::CallData::CallAttempt::Abandon() {
1230
- abandoned_ = true;
1231
- // Unref batches for deferred completion callbacks that will now never
1232
- // be invoked.
1233
- if (started_recv_trailing_metadata_ &&
1234
- !seen_recv_trailing_metadata_from_surface_) {
1235
- recv_trailing_metadata_internal_batch_.reset(
1236
- DEBUG_LOCATION,
1237
- "unref internal recv_trailing_metadata_ready batch; attempt abandoned");
1238
- }
1239
- GRPC_ERROR_UNREF(recv_trailing_metadata_error_);
1240
- recv_trailing_metadata_error_ = GRPC_ERROR_NONE;
1241
- recv_initial_metadata_ready_deferred_batch_.reset(
1242
- DEBUG_LOCATION,
1243
- "unref deferred recv_initial_metadata_ready batch; attempt abandoned");
1244
- GRPC_ERROR_UNREF(recv_initial_metadata_error_);
1245
- recv_initial_metadata_error_ = GRPC_ERROR_NONE;
1246
- recv_message_ready_deferred_batch_.reset(
1247
- DEBUG_LOCATION,
1248
- "unref deferred recv_message_ready batch; attempt abandoned");
1249
- GRPC_ERROR_UNREF(recv_message_error_);
1250
- recv_message_error_ = GRPC_ERROR_NONE;
1251
- for (auto& on_complete_deferred_batch : on_complete_deferred_batches_) {
1252
- on_complete_deferred_batch.batch.reset(
1253
- DEBUG_LOCATION, "unref deferred on_complete batch; attempt abandoned");
1254
- GRPC_ERROR_UNREF(on_complete_deferred_batch.error);
1255
- }
1256
- on_complete_deferred_batches_.clear();
1257
- }
1258
-
1259
- void RetryFilter::CallData::CallAttempt::OnPerAttemptRecvTimer(
1260
- void* arg, grpc_error_handle error) {
1261
- auto* call_attempt = static_cast<CallAttempt*>(arg);
1262
- GRPC_CLOSURE_INIT(&call_attempt->on_per_attempt_recv_timer_,
1263
- OnPerAttemptRecvTimerLocked, call_attempt, nullptr);
1264
- GRPC_CALL_COMBINER_START(call_attempt->calld_->call_combiner_,
1265
- &call_attempt->on_per_attempt_recv_timer_,
1266
- GRPC_ERROR_REF(error), "per-attempt timer fired");
1267
- }
1268
-
1269
- void RetryFilter::CallData::CallAttempt::OnPerAttemptRecvTimerLocked(
1270
- void* arg, grpc_error_handle error) {
1271
- auto* call_attempt = static_cast<CallAttempt*>(arg);
1272
- auto* calld = call_attempt->calld_;
1273
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1274
- gpr_log(GPR_INFO,
1275
- "chand=%p calld=%p attempt=%p: perAttemptRecvTimeout timer fired: "
1276
- "error=%s, per_attempt_recv_timer_pending_=%d",
1277
- calld->chand_, calld, call_attempt,
1278
- grpc_error_std_string(error).c_str(),
1279
- call_attempt->per_attempt_recv_timer_pending_);
1280
- }
1281
- CallCombinerClosureList closures;
1282
- if (GRPC_ERROR_IS_NONE(error) &&
1283
- call_attempt->per_attempt_recv_timer_pending_) {
1284
- call_attempt->per_attempt_recv_timer_pending_ = false;
1285
- // Cancel this attempt.
1286
- // TODO(roth): When implementing hedging, we should not cancel the
1287
- // current attempt.
1288
- call_attempt->MaybeAddBatchForCancelOp(
1289
- grpc_error_set_int(GRPC_ERROR_CREATE_FROM_STATIC_STRING(
1290
- "retry perAttemptRecvTimeout exceeded"),
1291
- GRPC_ERROR_INT_GRPC_STATUS, GRPC_STATUS_CANCELLED),
1292
- &closures);
1293
- // Check whether we should retry.
1294
- if (call_attempt->ShouldRetry(/*status=*/absl::nullopt,
1295
- /*server_pushback_ms=*/absl::nullopt)) {
1296
- // Mark current attempt as abandoned.
1297
- call_attempt->Abandon();
1298
- // We are retrying. Start backoff timer.
1299
- calld->StartRetryTimer(/*server_pushback=*/absl::nullopt);
1300
- } else {
1301
- // Not retrying, so commit the call.
1302
- calld->RetryCommit(call_attempt);
1303
- // If retry state is no longer needed, switch to fast path for
1304
- // subsequent batches.
1305
- call_attempt->MaybeSwitchToFastPath();
1306
- }
1307
- }
1308
- closures.RunClosures(calld->call_combiner_);
1309
- call_attempt->Unref(DEBUG_LOCATION, "OnPerAttemptRecvTimer");
1310
- GRPC_CALL_STACK_UNREF(calld->owning_call_, "OnPerAttemptRecvTimer");
1311
- }
1312
-
1313
- void RetryFilter::CallData::CallAttempt::MaybeCancelPerAttemptRecvTimer() {
1314
- if (per_attempt_recv_timer_pending_) {
1315
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1316
- gpr_log(GPR_INFO,
1317
- "chand=%p calld=%p attempt=%p: cancelling "
1318
- "perAttemptRecvTimeout timer",
1319
- calld_->chand_, calld_, this);
1320
- }
1321
- per_attempt_recv_timer_pending_ = false;
1322
- grpc_timer_cancel(&per_attempt_recv_timer_);
1323
- }
1324
- }
1325
-
1326
- //
1327
- // RetryFilter::CallData::CallAttempt::BatchData
1328
- //
1329
-
1330
- RetryFilter::CallData::CallAttempt::BatchData::BatchData(
1331
- RefCountedPtr<CallAttempt> attempt, int refcount, bool set_on_complete)
1332
- : RefCounted(
1333
- GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace) ? "BatchData" : nullptr,
1334
- refcount),
1335
- call_attempt_(attempt.release()) {
1336
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1337
- gpr_log(GPR_INFO, "chand=%p calld=%p attempt=%p: creating batch %p",
1338
- call_attempt_->calld_->chand_, call_attempt_->calld_, call_attempt_,
1339
- this);
1340
- }
1341
- // We hold a ref to the call stack for every batch sent on a call attempt.
1342
- // This is because some batches on the call attempt may not complete
1343
- // until after all of the batches are completed at the surface (because
1344
- // each batch that is pending at the surface holds a ref). This
1345
- // can happen for replayed send ops, and it can happen for
1346
- // recv_initial_metadata and recv_message ops on a call attempt that has
1347
- // been abandoned.
1348
- GRPC_CALL_STACK_REF(call_attempt_->calld_->owning_call_, "Retry BatchData");
1349
- batch_.payload = &call_attempt_->batch_payload_;
1350
- if (set_on_complete) {
1351
- GRPC_CLOSURE_INIT(&on_complete_, OnComplete, this, nullptr);
1352
- batch_.on_complete = &on_complete_;
1353
- }
1354
- }
1355
-
1356
- RetryFilter::CallData::CallAttempt::BatchData::~BatchData() {
1357
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1358
- gpr_log(GPR_INFO, "chand=%p calld=%p attempt=%p: destroying batch %p",
1359
- call_attempt_->calld_->chand_, call_attempt_->calld_, call_attempt_,
1360
- this);
1361
- }
1362
- CallAttempt* call_attempt = std::exchange(call_attempt_, nullptr);
1363
- GRPC_CALL_STACK_UNREF(call_attempt->calld_->owning_call_, "Retry BatchData");
1364
- call_attempt->Unref(DEBUG_LOCATION, "~BatchData");
1365
- }
1366
-
1367
- void RetryFilter::CallData::CallAttempt::BatchData::
1368
- FreeCachedSendOpDataForCompletedBatch() {
1369
- auto* calld = call_attempt_->calld_;
1370
- // TODO(roth): When we implement hedging, this logic will need to get
1371
- // a bit more complex, because there may be other (now abandoned) call
1372
- // attempts still using this data. We may need to do some sort of
1373
- // ref-counting instead.
1374
- if (batch_.send_initial_metadata) {
1375
- calld->FreeCachedSendInitialMetadata();
1376
- }
1377
- if (batch_.send_message) {
1378
- calld->FreeCachedSendMessage(call_attempt_->completed_send_message_count_ -
1379
- 1);
1380
- }
1381
- if (batch_.send_trailing_metadata) {
1382
- calld->FreeCachedSendTrailingMetadata();
1383
- }
1384
- }
1385
-
1386
- //
1387
- // recv_initial_metadata callback handling
1388
- //
1389
-
1390
- void RetryFilter::CallData::CallAttempt::BatchData::
1391
- MaybeAddClosureForRecvInitialMetadataCallback(
1392
- grpc_error_handle error, CallCombinerClosureList* closures) {
1393
- // Find pending batch.
1394
- PendingBatch* pending = call_attempt_->calld_->PendingBatchFind(
1395
- "invoking recv_initial_metadata_ready for",
1396
- [](grpc_transport_stream_op_batch* batch) {
1397
- return batch->recv_initial_metadata &&
1398
- batch->payload->recv_initial_metadata
1399
- .recv_initial_metadata_ready != nullptr;
1400
- });
1401
- if (pending == nullptr) {
1402
- GRPC_ERROR_UNREF(error);
1403
- return;
1404
- }
1405
- // Return metadata.
1406
- *pending->batch->payload->recv_initial_metadata.recv_initial_metadata =
1407
- std::move(call_attempt_->recv_initial_metadata_);
1408
- // Propagate trailing_metadata_available.
1409
- *pending->batch->payload->recv_initial_metadata.trailing_metadata_available =
1410
- call_attempt_->trailing_metadata_available_;
1411
- // Update bookkeeping.
1412
- // Note: Need to do this before invoking the callback, since invoking
1413
- // the callback will result in yielding the call combiner.
1414
- grpc_closure* recv_initial_metadata_ready =
1415
- pending->batch->payload->recv_initial_metadata
1416
- .recv_initial_metadata_ready;
1417
- pending->batch->payload->recv_initial_metadata.recv_initial_metadata_ready =
1418
- nullptr;
1419
- call_attempt_->calld_->MaybeClearPendingBatch(pending);
1420
- // Add callback to closures.
1421
- closures->Add(recv_initial_metadata_ready, error,
1422
- "recv_initial_metadata_ready for pending batch");
1423
- }
1424
-
1425
- void RetryFilter::CallData::CallAttempt::BatchData::RecvInitialMetadataReady(
1426
- void* arg, grpc_error_handle error) {
1427
- RefCountedPtr<BatchData> batch_data(static_cast<BatchData*>(arg));
1428
- CallAttempt* call_attempt = batch_data->call_attempt_;
1429
- CallData* calld = call_attempt->calld_;
1430
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1431
- gpr_log(GPR_INFO,
1432
- "chand=%p calld=%p attempt=%p batch_data=%p: "
1433
- "got recv_initial_metadata_ready, error=%s",
1434
- calld->chand_, calld, call_attempt, batch_data.get(),
1435
- grpc_error_std_string(error).c_str());
1436
- }
1437
- call_attempt->completed_recv_initial_metadata_ = true;
1438
- // If this attempt has been abandoned, then we're not going to use the
1439
- // result of this recv_initial_metadata op, so do nothing.
1440
- if (call_attempt->abandoned_) {
1441
- GRPC_CALL_COMBINER_STOP(
1442
- calld->call_combiner_,
1443
- "recv_initial_metadata_ready for abandoned attempt");
1444
- return;
1445
- }
1446
- // Cancel per-attempt recv timer, if any.
1447
- call_attempt->MaybeCancelPerAttemptRecvTimer();
1448
- // If we're not committed, check the response to see if we need to commit.
1449
- if (!calld->retry_committed_) {
1450
- // If we got an error or a Trailers-Only response and have not yet gotten
1451
- // the recv_trailing_metadata_ready callback, then defer propagating this
1452
- // callback back to the surface. We can evaluate whether to retry when
1453
- // recv_trailing_metadata comes back.
1454
- if (GPR_UNLIKELY((call_attempt->trailing_metadata_available_ ||
1455
- !GRPC_ERROR_IS_NONE(error)) &&
1456
- !call_attempt->completed_recv_trailing_metadata_)) {
1457
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1458
- gpr_log(GPR_INFO,
1459
- "chand=%p calld=%p attempt=%p: deferring "
1460
- "recv_initial_metadata_ready (Trailers-Only)",
1461
- calld->chand_, calld, call_attempt);
1462
- }
1463
- call_attempt->recv_initial_metadata_ready_deferred_batch_ =
1464
- std::move(batch_data);
1465
- call_attempt->recv_initial_metadata_error_ = GRPC_ERROR_REF(error);
1466
- CallCombinerClosureList closures;
1467
- if (!GRPC_ERROR_IS_NONE(error)) {
1468
- call_attempt->MaybeAddBatchForCancelOp(GRPC_ERROR_REF(error),
1469
- &closures);
1470
- }
1471
- if (!call_attempt->started_recv_trailing_metadata_) {
1472
- // recv_trailing_metadata not yet started by application; start it
1473
- // ourselves to get status.
1474
- call_attempt->AddBatchForInternalRecvTrailingMetadata(&closures);
1475
- }
1476
- closures.RunClosures(calld->call_combiner_);
1477
- return;
1478
- }
1479
- // Received valid initial metadata, so commit the call.
1480
- calld->RetryCommit(call_attempt);
1481
- // If retry state is no longer needed, switch to fast path for
1482
- // subsequent batches.
1483
- call_attempt->MaybeSwitchToFastPath();
1484
- }
1485
- // Invoke the callback to return the result to the surface.
1486
- CallCombinerClosureList closures;
1487
- batch_data->MaybeAddClosureForRecvInitialMetadataCallback(
1488
- GRPC_ERROR_REF(error), &closures);
1489
- closures.RunClosures(calld->call_combiner_);
1490
- }
1491
-
1492
- //
1493
- // recv_message callback handling
1494
- //
1495
-
1496
- void RetryFilter::CallData::CallAttempt::BatchData::
1497
- MaybeAddClosureForRecvMessageCallback(grpc_error_handle error,
1498
- CallCombinerClosureList* closures) {
1499
- // Find pending op.
1500
- PendingBatch* pending = call_attempt_->calld_->PendingBatchFind(
1501
- "invoking recv_message_ready for",
1502
- [](grpc_transport_stream_op_batch* batch) {
1503
- return batch->recv_message &&
1504
- batch->payload->recv_message.recv_message_ready != nullptr;
1505
- });
1506
- if (pending == nullptr) {
1507
- GRPC_ERROR_UNREF(error);
1508
- return;
1509
- }
1510
- // Return payload.
1511
- *pending->batch->payload->recv_message.recv_message =
1512
- std::move(call_attempt_->recv_message_);
1513
- *pending->batch->payload->recv_message.flags =
1514
- call_attempt_->recv_message_flags_;
1515
- // Update bookkeeping.
1516
- // Note: Need to do this before invoking the callback, since invoking
1517
- // the callback will result in yielding the call combiner.
1518
- grpc_closure* recv_message_ready =
1519
- pending->batch->payload->recv_message.recv_message_ready;
1520
- pending->batch->payload->recv_message.recv_message_ready = nullptr;
1521
- call_attempt_->calld_->MaybeClearPendingBatch(pending);
1522
- // Add callback to closures.
1523
- closures->Add(recv_message_ready, error,
1524
- "recv_message_ready for pending batch");
1525
- }
1526
-
1527
- void RetryFilter::CallData::CallAttempt::BatchData::RecvMessageReady(
1528
- void* arg, grpc_error_handle error) {
1529
- RefCountedPtr<BatchData> batch_data(static_cast<BatchData*>(arg));
1530
- CallAttempt* call_attempt = batch_data->call_attempt_;
1531
- CallData* calld = call_attempt->calld_;
1532
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1533
- gpr_log(GPR_INFO,
1534
- "chand=%p calld=%p attempt=%p batch_data=%p: "
1535
- "got recv_message_ready, error=%s",
1536
- calld->chand_, calld, call_attempt, batch_data.get(),
1537
- grpc_error_std_string(error).c_str());
1538
- }
1539
- ++call_attempt->completed_recv_message_count_;
1540
- // If this attempt has been abandoned, then we're not going to use the
1541
- // result of this recv_message op, so do nothing.
1542
- if (call_attempt->abandoned_) {
1543
- // The transport will not invoke recv_trailing_metadata_ready until the byte
1544
- // stream for any recv_message op is orphaned, so we do that here to ensure
1545
- // that any pending recv_trailing_metadata op can complete.
1546
- call_attempt->recv_message_.reset();
1547
- GRPC_CALL_COMBINER_STOP(calld->call_combiner_,
1548
- "recv_message_ready for abandoned attempt");
1549
- return;
1550
- }
1551
- // Cancel per-attempt recv timer, if any.
1552
- call_attempt->MaybeCancelPerAttemptRecvTimer();
1553
- // If we're not committed, check the response to see if we need to commit.
1554
- if (!calld->retry_committed_) {
1555
- // If we got an error or the payload was nullptr and we have not yet gotten
1556
- // the recv_trailing_metadata_ready callback, then defer propagating this
1557
- // callback back to the surface. We can evaluate whether to retry when
1558
- // recv_trailing_metadata comes back.
1559
- if (GPR_UNLIKELY((!call_attempt->recv_message_.has_value() ||
1560
- !GRPC_ERROR_IS_NONE(error)) &&
1561
- !call_attempt->completed_recv_trailing_metadata_)) {
1562
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1563
- gpr_log(GPR_INFO,
1564
- "chand=%p calld=%p attempt=%p: deferring recv_message_ready "
1565
- "(nullptr message and recv_trailing_metadata pending)",
1566
- calld->chand_, calld, call_attempt);
1567
- }
1568
- call_attempt->recv_message_ready_deferred_batch_ = std::move(batch_data);
1569
- call_attempt->recv_message_error_ = GRPC_ERROR_REF(error);
1570
- CallCombinerClosureList closures;
1571
- if (!GRPC_ERROR_IS_NONE(error)) {
1572
- call_attempt->MaybeAddBatchForCancelOp(GRPC_ERROR_REF(error),
1573
- &closures);
1574
- }
1575
- if (!call_attempt->started_recv_trailing_metadata_) {
1576
- // recv_trailing_metadata not yet started by application; start it
1577
- // ourselves to get status.
1578
- call_attempt->AddBatchForInternalRecvTrailingMetadata(&closures);
1579
- }
1580
- closures.RunClosures(calld->call_combiner_);
1581
- return;
1582
- }
1583
- // Received a valid message, so commit the call.
1584
- calld->RetryCommit(call_attempt);
1585
- // If retry state is no longer needed, switch to fast path for
1586
- // subsequent batches.
1587
- call_attempt->MaybeSwitchToFastPath();
1588
- }
1589
- // Invoke the callback to return the result to the surface.
1590
- CallCombinerClosureList closures;
1591
- batch_data->MaybeAddClosureForRecvMessageCallback(GRPC_ERROR_REF(error),
1592
- &closures);
1593
- closures.RunClosures(calld->call_combiner_);
1594
- }
1595
-
1596
- //
1597
- // recv_trailing_metadata handling
1598
- //
1599
-
1600
- namespace {
1601
-
1602
- // Sets *status, *server_pushback, and *is_lb_drop based on md_batch
1603
- // and error.
1604
- void GetCallStatus(
1605
- Timestamp deadline, grpc_metadata_batch* md_batch, grpc_error_handle error,
1606
- grpc_status_code* status, absl::optional<Duration>* server_pushback,
1607
- bool* is_lb_drop,
1608
- absl::optional<GrpcStreamNetworkState::ValueType>* stream_network_state) {
1609
- if (!GRPC_ERROR_IS_NONE(error)) {
1610
- grpc_error_get_status(error, deadline, status, nullptr, nullptr, nullptr);
1611
- intptr_t value = 0;
1612
- if (grpc_error_get_int(error, GRPC_ERROR_INT_LB_POLICY_DROP, &value) &&
1613
- value != 0) {
1614
- *is_lb_drop = true;
1615
- }
1616
- } else {
1617
- *status = *md_batch->get(GrpcStatusMetadata());
1618
- }
1619
- *server_pushback = md_batch->get(GrpcRetryPushbackMsMetadata());
1620
- *stream_network_state = md_batch->get(GrpcStreamNetworkState());
1621
- GRPC_ERROR_UNREF(error);
1622
- }
1623
-
1624
- } // namespace
1625
-
1626
- void RetryFilter::CallData::CallAttempt::BatchData::
1627
- MaybeAddClosureForRecvTrailingMetadataReady(
1628
- grpc_error_handle error, CallCombinerClosureList* closures) {
1629
- auto* calld = call_attempt_->calld_;
1630
- // Find pending batch.
1631
- PendingBatch* pending = calld->PendingBatchFind(
1632
- "invoking recv_trailing_metadata_ready for",
1633
- [](grpc_transport_stream_op_batch* batch) {
1634
- return batch->recv_trailing_metadata &&
1635
- batch->payload->recv_trailing_metadata
1636
- .recv_trailing_metadata_ready != nullptr;
1637
- });
1638
- // If we generated the recv_trailing_metadata op internally via
1639
- // AddBatchForInternalRecvTrailingMetadata(), then there will be no
1640
- // pending batch.
1641
- if (pending == nullptr) {
1642
- call_attempt_->recv_trailing_metadata_error_ = error;
1643
- return;
1644
- }
1645
- // Copy transport stats to be delivered up to the surface.
1646
- grpc_transport_move_stats(
1647
- &call_attempt_->collect_stats_,
1648
- pending->batch->payload->recv_trailing_metadata.collect_stats);
1649
- // Return metadata.
1650
- *pending->batch->payload->recv_trailing_metadata.recv_trailing_metadata =
1651
- std::move(call_attempt_->recv_trailing_metadata_);
1652
- // Add closure.
1653
- closures->Add(pending->batch->payload->recv_trailing_metadata
1654
- .recv_trailing_metadata_ready,
1655
- error, "recv_trailing_metadata_ready for pending batch");
1656
- // Update bookkeeping.
1657
- pending->batch->payload->recv_trailing_metadata.recv_trailing_metadata_ready =
1658
- nullptr;
1659
- calld->MaybeClearPendingBatch(pending);
1660
- }
1661
-
1662
- void RetryFilter::CallData::CallAttempt::BatchData::
1663
- AddClosuresForDeferredCompletionCallbacks(
1664
- CallCombinerClosureList* closures) {
1665
- // Add closure for deferred recv_initial_metadata_ready.
1666
- if (GPR_UNLIKELY(call_attempt_->recv_initial_metadata_ready_deferred_batch_ !=
1667
- nullptr)) {
1668
- MaybeAddClosureForRecvInitialMetadataCallback(
1669
- call_attempt_->recv_initial_metadata_error_, closures);
1670
- call_attempt_->recv_initial_metadata_ready_deferred_batch_.reset(
1671
- DEBUG_LOCATION, "resuming deferred recv_initial_metadata_ready");
1672
- call_attempt_->recv_initial_metadata_error_ = GRPC_ERROR_NONE;
1673
- }
1674
- // Add closure for deferred recv_message_ready.
1675
- if (GPR_UNLIKELY(call_attempt_->recv_message_ready_deferred_batch_ !=
1676
- nullptr)) {
1677
- MaybeAddClosureForRecvMessageCallback(call_attempt_->recv_message_error_,
1678
- closures);
1679
- call_attempt_->recv_message_ready_deferred_batch_.reset(
1680
- DEBUG_LOCATION, "resuming deferred recv_message_ready");
1681
- call_attempt_->recv_message_error_ = GRPC_ERROR_NONE;
1682
- }
1683
- // Add closures for deferred on_complete callbacks.
1684
- for (auto& on_complete_deferred_batch :
1685
- call_attempt_->on_complete_deferred_batches_) {
1686
- closures->Add(&on_complete_deferred_batch.batch->on_complete_,
1687
- on_complete_deferred_batch.error, "resuming on_complete");
1688
- on_complete_deferred_batch.batch.release();
1689
- }
1690
- call_attempt_->on_complete_deferred_batches_.clear();
1691
- }
1692
-
1693
- void RetryFilter::CallData::CallAttempt::BatchData::
1694
- AddClosuresToFailUnstartedPendingBatches(
1695
- grpc_error_handle error, CallCombinerClosureList* closures) {
1696
- auto* calld = call_attempt_->calld_;
1697
- for (size_t i = 0; i < GPR_ARRAY_SIZE(calld->pending_batches_); ++i) {
1698
- PendingBatch* pending = &calld->pending_batches_[i];
1699
- if (pending->batch == nullptr) continue;
1700
- if (call_attempt_->PendingBatchContainsUnstartedSendOps(pending)) {
1701
- closures->Add(pending->batch->on_complete, GRPC_ERROR_REF(error),
1702
- "failing on_complete for pending batch");
1703
- pending->batch->on_complete = nullptr;
1704
- calld->MaybeClearPendingBatch(pending);
1705
- }
1706
- }
1707
- GRPC_ERROR_UNREF(error);
1708
- }
1709
-
1710
- void RetryFilter::CallData::CallAttempt::BatchData::RunClosuresForCompletedCall(
1711
- grpc_error_handle error) {
1712
- // Construct list of closures to execute.
1713
- CallCombinerClosureList closures;
1714
- // First, add closure for recv_trailing_metadata_ready.
1715
- MaybeAddClosureForRecvTrailingMetadataReady(GRPC_ERROR_REF(error), &closures);
1716
- // If there are deferred batch completion callbacks, add them to closures.
1717
- AddClosuresForDeferredCompletionCallbacks(&closures);
1718
- // Add closures to fail any pending batches that have not yet been started.
1719
- AddClosuresToFailUnstartedPendingBatches(GRPC_ERROR_REF(error), &closures);
1720
- // Schedule all of the closures identified above.
1721
- // Note: This will release the call combiner.
1722
- closures.RunClosures(call_attempt_->calld_->call_combiner_);
1723
- GRPC_ERROR_UNREF(error);
1724
- }
1725
-
1726
- void RetryFilter::CallData::CallAttempt::BatchData::RecvTrailingMetadataReady(
1727
- void* arg, grpc_error_handle error) {
1728
- RefCountedPtr<BatchData> batch_data(static_cast<BatchData*>(arg));
1729
- CallAttempt* call_attempt = batch_data->call_attempt_;
1730
- CallData* calld = call_attempt->calld_;
1731
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1732
- gpr_log(GPR_INFO,
1733
- "chand=%p calld=%p attempt=%p batch_data=%p: "
1734
- "got recv_trailing_metadata_ready, error=%s",
1735
- calld->chand_, calld, call_attempt, batch_data.get(),
1736
- grpc_error_std_string(error).c_str());
1737
- }
1738
- call_attempt->completed_recv_trailing_metadata_ = true;
1739
- // If this attempt has been abandoned, then we're not going to use the
1740
- // result of this recv_trailing_metadata op, so do nothing.
1741
- if (call_attempt->abandoned_) {
1742
- GRPC_CALL_COMBINER_STOP(
1743
- calld->call_combiner_,
1744
- "recv_trailing_metadata_ready for abandoned attempt");
1745
- return;
1746
- }
1747
- // Cancel per-attempt recv timer, if any.
1748
- call_attempt->MaybeCancelPerAttemptRecvTimer();
1749
- // Get the call's status and check for server pushback metadata.
1750
- grpc_status_code status = GRPC_STATUS_OK;
1751
- absl::optional<Duration> server_pushback;
1752
- bool is_lb_drop = false;
1753
- absl::optional<GrpcStreamNetworkState::ValueType> stream_network_state;
1754
- grpc_metadata_batch* md_batch =
1755
- batch_data->batch_.payload->recv_trailing_metadata.recv_trailing_metadata;
1756
- GetCallStatus(calld->deadline_, md_batch, GRPC_ERROR_REF(error), &status,
1757
- &server_pushback, &is_lb_drop, &stream_network_state);
1758
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1759
- gpr_log(GPR_INFO,
1760
- "chand=%p calld=%p attempt=%p: call finished, status=%s "
1761
- "server_pushback=%s is_lb_drop=%d stream_network_state=%s",
1762
- calld->chand_, calld, call_attempt,
1763
- grpc_status_code_to_string(status),
1764
- server_pushback.has_value() ? server_pushback->ToString().c_str()
1765
- : "N/A",
1766
- is_lb_drop,
1767
- stream_network_state.has_value()
1768
- ? absl::StrCat(*stream_network_state).c_str()
1769
- : "N/A");
1770
- }
1771
- // Check if we should retry.
1772
- if (!is_lb_drop) { // Never retry on LB drops.
1773
- enum { kNoRetry, kTransparentRetry, kConfigurableRetry } retry = kNoRetry;
1774
- // Handle transparent retries.
1775
- if (stream_network_state.has_value() && !calld->retry_committed_) {
1776
- // If not sent on wire, then always retry.
1777
- // If sent on wire but not seen by server, retry exactly once.
1778
- if (*stream_network_state == GrpcStreamNetworkState::kNotSentOnWire) {
1779
- retry = kTransparentRetry;
1780
- } else if (*stream_network_state ==
1781
- GrpcStreamNetworkState::kNotSeenByServer &&
1782
- !calld->sent_transparent_retry_not_seen_by_server_) {
1783
- calld->sent_transparent_retry_not_seen_by_server_ = true;
1784
- retry = kTransparentRetry;
1785
- }
1786
- }
1787
- // If not transparently retrying, check for configurable retry.
1788
- if (retry == kNoRetry &&
1789
- call_attempt->ShouldRetry(status, server_pushback)) {
1790
- retry = kConfigurableRetry;
1791
- }
1792
- // If we're retrying, do so.
1793
- if (retry != kNoRetry) {
1794
- CallCombinerClosureList closures;
1795
- // Cancel call attempt.
1796
- call_attempt->MaybeAddBatchForCancelOp(
1797
- GRPC_ERROR_IS_NONE(error)
1798
- ? grpc_error_set_int(
1799
- GRPC_ERROR_CREATE_FROM_STATIC_STRING("call attempt failed"),
1800
- GRPC_ERROR_INT_GRPC_STATUS, GRPC_STATUS_CANCELLED)
1801
- : GRPC_ERROR_REF(error),
1802
- &closures);
1803
- // For transparent retries, add a closure to immediately start a new
1804
- // call attempt.
1805
- // For configurable retries, start retry timer.
1806
- if (retry == kTransparentRetry) {
1807
- calld->AddClosureToStartTransparentRetry(&closures);
1808
- } else {
1809
- calld->StartRetryTimer(server_pushback);
1810
- }
1811
- // Record that this attempt has been abandoned.
1812
- call_attempt->Abandon();
1813
- // Yields call combiner.
1814
- closures.RunClosures(calld->call_combiner_);
1815
- return;
1816
- }
1817
- }
1818
- // Not retrying, so commit the call.
1819
- calld->RetryCommit(call_attempt);
1820
- // If retry state is no longer needed, switch to fast path for
1821
- // subsequent batches.
1822
- call_attempt->MaybeSwitchToFastPath();
1823
- // Run any necessary closures.
1824
- batch_data->RunClosuresForCompletedCall(GRPC_ERROR_REF(error));
1825
- }
1826
-
1827
- //
1828
- // on_complete callback handling
1829
- //
1830
-
1831
- void RetryFilter::CallData::CallAttempt::BatchData::
1832
- AddClosuresForCompletedPendingBatch(grpc_error_handle error,
1833
- CallCombinerClosureList* closures) {
1834
- auto* calld = call_attempt_->calld_;
1835
- PendingBatch* pending = calld->PendingBatchFind(
1836
- "completed", [this](grpc_transport_stream_op_batch* batch) {
1837
- // Match the pending batch with the same set of send ops as the
1838
- // batch we've just completed.
1839
- return batch->on_complete != nullptr &&
1840
- batch_.send_initial_metadata == batch->send_initial_metadata &&
1841
- batch_.send_message == batch->send_message &&
1842
- batch_.send_trailing_metadata == batch->send_trailing_metadata;
1843
- });
1844
- // If batch_data is a replay batch, then there will be no pending
1845
- // batch to complete.
1846
- if (pending == nullptr) {
1847
- GRPC_ERROR_UNREF(error);
1848
- return;
1849
- }
1850
- // Propagate payload.
1851
- if (batch_.send_message) {
1852
- pending->batch->payload->send_message.stream_write_closed =
1853
- batch_.payload->send_message.stream_write_closed;
1854
- }
1855
- // Add closure.
1856
- closures->Add(pending->batch->on_complete, error,
1857
- "on_complete for pending batch");
1858
- pending->batch->on_complete = nullptr;
1859
- calld->MaybeClearPendingBatch(pending);
1860
- }
1861
-
1862
- void RetryFilter::CallData::CallAttempt::BatchData::
1863
- AddClosuresForReplayOrPendingSendOps(CallCombinerClosureList* closures) {
1864
- auto* calld = call_attempt_->calld_;
1865
- bool have_pending_send_ops = call_attempt_->HaveSendOpsToReplay();
1866
- // We don't check send_initial_metadata here, because that op will always
1867
- // be started as soon as it is received from the surface, so it will
1868
- // never need to be started at this point.
1869
- if (!have_pending_send_ops) {
1870
- for (size_t i = 0; i < GPR_ARRAY_SIZE(calld->pending_batches_); ++i) {
1871
- PendingBatch* pending = &calld->pending_batches_[i];
1872
- grpc_transport_stream_op_batch* batch = pending->batch;
1873
- if (batch == nullptr || pending->send_ops_cached) continue;
1874
- if (batch->send_message || batch->send_trailing_metadata) {
1875
- have_pending_send_ops = true;
1876
- break;
1877
- }
1878
- }
1879
- }
1880
- if (have_pending_send_ops) {
1881
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1882
- gpr_log(GPR_INFO,
1883
- "chand=%p calld=%p attempt=%p: starting next batch for pending "
1884
- "send op(s)",
1885
- calld->chand_, calld, call_attempt_);
1886
- }
1887
- call_attempt_->AddRetriableBatches(closures);
1888
- }
1889
- }
1890
-
1891
- void RetryFilter::CallData::CallAttempt::BatchData::OnComplete(
1892
- void* arg, grpc_error_handle error) {
1893
- RefCountedPtr<BatchData> batch_data(static_cast<BatchData*>(arg));
1894
- CallAttempt* call_attempt = batch_data->call_attempt_;
1895
- CallData* calld = call_attempt->calld_;
1896
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1897
- gpr_log(GPR_INFO,
1898
- "chand=%p calld=%p attempt=%p batch_data=%p: "
1899
- "got on_complete, error=%s, batch=%s",
1900
- calld->chand_, calld, call_attempt, batch_data.get(),
1901
- grpc_error_std_string(error).c_str(),
1902
- grpc_transport_stream_op_batch_string(&batch_data->batch_).c_str());
1903
- }
1904
- // If this attempt has been abandoned, then we're not going to propagate
1905
- // the completion of this batch, so do nothing.
1906
- if (call_attempt->abandoned_) {
1907
- GRPC_CALL_COMBINER_STOP(calld->call_combiner_,
1908
- "on_complete for abandoned attempt");
1909
- return;
1910
- }
1911
- // If we got an error and have not yet gotten the
1912
- // recv_trailing_metadata_ready callback, then defer propagating this
1913
- // callback back to the surface. We can evaluate whether to retry when
1914
- // recv_trailing_metadata comes back.
1915
- if (GPR_UNLIKELY(!calld->retry_committed_ && !GRPC_ERROR_IS_NONE(error) &&
1916
- !call_attempt->completed_recv_trailing_metadata_)) {
1917
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1918
- gpr_log(GPR_INFO, "chand=%p calld=%p attempt=%p: deferring on_complete",
1919
- calld->chand_, calld, call_attempt);
1920
- }
1921
- call_attempt->on_complete_deferred_batches_.emplace_back(
1922
- std::move(batch_data), GRPC_ERROR_REF(error));
1923
- CallCombinerClosureList closures;
1924
- call_attempt->MaybeAddBatchForCancelOp(GRPC_ERROR_REF(error), &closures);
1925
- if (!call_attempt->started_recv_trailing_metadata_) {
1926
- // recv_trailing_metadata not yet started by application; start it
1927
- // ourselves to get status.
1928
- call_attempt->AddBatchForInternalRecvTrailingMetadata(&closures);
1929
- }
1930
- closures.RunClosures(calld->call_combiner_);
1931
- return;
1932
- }
1933
- // Update bookkeeping in call_attempt.
1934
- if (batch_data->batch_.send_initial_metadata) {
1935
- call_attempt->completed_send_initial_metadata_ = true;
1936
- }
1937
- if (batch_data->batch_.send_message) {
1938
- ++call_attempt->completed_send_message_count_;
1939
- }
1940
- if (batch_data->batch_.send_trailing_metadata) {
1941
- call_attempt->completed_send_trailing_metadata_ = true;
1942
- }
1943
- // If the call is committed, free cached data for send ops that we've just
1944
- // completed.
1945
- if (calld->retry_committed_) {
1946
- batch_data->FreeCachedSendOpDataForCompletedBatch();
1947
- }
1948
- // Construct list of closures to execute.
1949
- CallCombinerClosureList closures;
1950
- // Add closure for the completed pending batch, if any.
1951
- batch_data->AddClosuresForCompletedPendingBatch(GRPC_ERROR_REF(error),
1952
- &closures);
1953
- // If needed, add a callback to start any replay or pending send ops on
1954
- // the LB call.
1955
- if (!call_attempt->completed_recv_trailing_metadata_) {
1956
- batch_data->AddClosuresForReplayOrPendingSendOps(&closures);
1957
- }
1958
- // If retry state is no longer needed (i.e., we're committed and there
1959
- // are no more send ops to replay), switch to fast path for subsequent
1960
- // batches.
1961
- call_attempt->MaybeSwitchToFastPath();
1962
- // Schedule all of the closures identified above.
1963
- // Note: This yields the call combiner.
1964
- closures.RunClosures(calld->call_combiner_);
1965
- }
1966
-
1967
- void RetryFilter::CallData::CallAttempt::BatchData::OnCompleteForCancelOp(
1968
- void* arg, grpc_error_handle error) {
1969
- RefCountedPtr<BatchData> batch_data(static_cast<BatchData*>(arg));
1970
- CallAttempt* call_attempt = batch_data->call_attempt_;
1971
- CallData* calld = call_attempt->calld_;
1972
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
1973
- gpr_log(GPR_INFO,
1974
- "chand=%p calld=%p attempt=%p batch_data=%p: "
1975
- "got on_complete for cancel_stream batch, error=%s, batch=%s",
1976
- calld->chand_, calld, call_attempt, batch_data.get(),
1977
- grpc_error_std_string(error).c_str(),
1978
- grpc_transport_stream_op_batch_string(&batch_data->batch_).c_str());
1979
- }
1980
- GRPC_CALL_COMBINER_STOP(
1981
- calld->call_combiner_,
1982
- "on_complete for internally generated cancel_stream op");
1983
- }
1984
-
1985
- //
1986
- // retriable batch construction
1987
- //
1988
-
1989
- void RetryFilter::CallData::CallAttempt::BatchData::
1990
- AddRetriableSendInitialMetadataOp() {
1991
- auto* calld = call_attempt_->calld_;
1992
- // We need to make a copy of the metadata batch for each attempt, since
1993
- // the filters in the subchannel stack may modify this batch, and we don't
1994
- // want those modifications to be passed forward to subsequent attempts.
1995
- //
1996
- // If we've already completed one or more attempts, add the
1997
- // grpc-retry-attempts header.
1998
- call_attempt_->send_initial_metadata_ = calld->send_initial_metadata_.Copy();
1999
- if (GPR_UNLIKELY(calld->num_attempts_completed_ > 0)) {
2000
- call_attempt_->send_initial_metadata_.Set(GrpcPreviousRpcAttemptsMetadata(),
2001
- calld->num_attempts_completed_);
2002
- } else {
2003
- call_attempt_->send_initial_metadata_.Remove(
2004
- GrpcPreviousRpcAttemptsMetadata());
2005
- }
2006
- call_attempt_->started_send_initial_metadata_ = true;
2007
- batch_.send_initial_metadata = true;
2008
- batch_.payload->send_initial_metadata.send_initial_metadata =
2009
- &call_attempt_->send_initial_metadata_;
2010
- batch_.payload->send_initial_metadata.peer_string = calld->peer_string_;
2011
- }
2012
-
2013
- void RetryFilter::CallData::CallAttempt::BatchData::
2014
- AddRetriableSendMessageOp() {
2015
- auto* calld = call_attempt_->calld_;
2016
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2017
- gpr_log(
2018
- GPR_INFO,
2019
- "chand=%p calld=%p attempt=%p: starting calld->send_messages[%" PRIuPTR
2020
- "]",
2021
- calld->chand_, calld, call_attempt_,
2022
- call_attempt_->started_send_message_count_);
2023
- }
2024
- CachedSendMessage cache =
2025
- calld->send_messages_[call_attempt_->started_send_message_count_];
2026
- ++call_attempt_->started_send_message_count_;
2027
- batch_.send_message = true;
2028
- batch_.payload->send_message.send_message = cache.slices;
2029
- batch_.payload->send_message.flags = cache.flags;
2030
- }
2031
-
2032
- void RetryFilter::CallData::CallAttempt::BatchData::
2033
- AddRetriableSendTrailingMetadataOp() {
2034
- auto* calld = call_attempt_->calld_;
2035
- // We need to make a copy of the metadata batch for each attempt, since
2036
- // the filters in the subchannel stack may modify this batch, and we don't
2037
- // want those modifications to be passed forward to subsequent attempts.
2038
- call_attempt_->send_trailing_metadata_ =
2039
- calld->send_trailing_metadata_.Copy();
2040
- call_attempt_->started_send_trailing_metadata_ = true;
2041
- batch_.send_trailing_metadata = true;
2042
- batch_.payload->send_trailing_metadata.send_trailing_metadata =
2043
- &call_attempt_->send_trailing_metadata_;
2044
- }
2045
-
2046
- void RetryFilter::CallData::CallAttempt::BatchData::
2047
- AddRetriableRecvInitialMetadataOp() {
2048
- call_attempt_->started_recv_initial_metadata_ = true;
2049
- batch_.recv_initial_metadata = true;
2050
- call_attempt_->recv_initial_metadata_.Clear();
2051
- batch_.payload->recv_initial_metadata.recv_initial_metadata =
2052
- &call_attempt_->recv_initial_metadata_;
2053
- batch_.payload->recv_initial_metadata.trailing_metadata_available =
2054
- &call_attempt_->trailing_metadata_available_;
2055
- GRPC_CLOSURE_INIT(&call_attempt_->recv_initial_metadata_ready_,
2056
- RecvInitialMetadataReady, this, grpc_schedule_on_exec_ctx);
2057
- batch_.payload->recv_initial_metadata.recv_initial_metadata_ready =
2058
- &call_attempt_->recv_initial_metadata_ready_;
2059
- }
2060
-
2061
- void RetryFilter::CallData::CallAttempt::BatchData::
2062
- AddRetriableRecvMessageOp() {
2063
- ++call_attempt_->started_recv_message_count_;
2064
- batch_.recv_message = true;
2065
- batch_.payload->recv_message.recv_message = &call_attempt_->recv_message_;
2066
- batch_.payload->recv_message.flags = &call_attempt_->recv_message_flags_;
2067
- batch_.payload->recv_message.call_failed_before_recv_message = nullptr;
2068
- GRPC_CLOSURE_INIT(&call_attempt_->recv_message_ready_, RecvMessageReady, this,
2069
- grpc_schedule_on_exec_ctx);
2070
- batch_.payload->recv_message.recv_message_ready =
2071
- &call_attempt_->recv_message_ready_;
2072
- }
2073
-
2074
- void RetryFilter::CallData::CallAttempt::BatchData::
2075
- AddRetriableRecvTrailingMetadataOp() {
2076
- call_attempt_->started_recv_trailing_metadata_ = true;
2077
- batch_.recv_trailing_metadata = true;
2078
- call_attempt_->recv_trailing_metadata_.Clear();
2079
- batch_.payload->recv_trailing_metadata.recv_trailing_metadata =
2080
- &call_attempt_->recv_trailing_metadata_;
2081
- batch_.payload->recv_trailing_metadata.collect_stats =
2082
- &call_attempt_->collect_stats_;
2083
- GRPC_CLOSURE_INIT(&call_attempt_->recv_trailing_metadata_ready_,
2084
- RecvTrailingMetadataReady, this, grpc_schedule_on_exec_ctx);
2085
- batch_.payload->recv_trailing_metadata.recv_trailing_metadata_ready =
2086
- &call_attempt_->recv_trailing_metadata_ready_;
2087
- }
2088
-
2089
- void RetryFilter::CallData::CallAttempt::BatchData::AddCancelStreamOp(
2090
- grpc_error_handle error) {
2091
- batch_.cancel_stream = true;
2092
- batch_.payload->cancel_stream.cancel_error = error;
2093
- // Override on_complete callback.
2094
- GRPC_CLOSURE_INIT(&on_complete_, OnCompleteForCancelOp, this, nullptr);
2095
- }
2096
-
2097
- //
2098
- // CallData vtable functions
2099
- //
2100
-
2101
- grpc_error_handle RetryFilter::CallData::Init(
2102
- grpc_call_element* elem, const grpc_call_element_args* args) {
2103
- auto* chand = static_cast<RetryFilter*>(elem->channel_data);
2104
- new (elem->call_data) CallData(chand, *args);
2105
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2106
- gpr_log(GPR_INFO, "chand=%p calld=%p: created call", chand,
2107
- elem->call_data);
2108
- }
2109
- return GRPC_ERROR_NONE;
2110
- }
2111
-
2112
- void RetryFilter::CallData::Destroy(grpc_call_element* elem,
2113
- const grpc_call_final_info* /*final_info*/,
2114
- grpc_closure* then_schedule_closure) {
2115
- auto* calld = static_cast<CallData*>(elem->call_data);
2116
- // Save our ref to the CallStackDestructionBarrier until after our
2117
- // dtor is invoked.
2118
- RefCountedPtr<CallStackDestructionBarrier> call_stack_destruction_barrier =
2119
- std::move(calld->call_stack_destruction_barrier_);
2120
- calld->~CallData();
2121
- // Now set the callback in the CallStackDestructionBarrier object,
2122
- // right before we release our ref to it (implicitly upon returning).
2123
- // The callback will be invoked when the CallStackDestructionBarrier
2124
- // is destroyed.
2125
- call_stack_destruction_barrier->set_on_call_stack_destruction(
2126
- then_schedule_closure);
2127
- }
2128
-
2129
- void RetryFilter::CallData::StartTransportStreamOpBatch(
2130
- grpc_call_element* elem, grpc_transport_stream_op_batch* batch) {
2131
- auto* calld = static_cast<CallData*>(elem->call_data);
2132
- calld->StartTransportStreamOpBatch(batch);
2133
- }
2134
-
2135
- void RetryFilter::CallData::SetPollent(grpc_call_element* elem,
2136
- grpc_polling_entity* pollent) {
2137
- auto* calld = static_cast<CallData*>(elem->call_data);
2138
- calld->pollent_ = pollent;
2139
- }
2140
-
2141
- //
2142
- // CallData implementation
2143
- //
2144
-
2145
- const RetryMethodConfig* RetryFilter::GetRetryPolicy(
2146
- const grpc_call_context_element* context) {
2147
- if (context == nullptr) return nullptr;
2148
- auto* svc_cfg_call_data = static_cast<ServiceConfigCallData*>(
2149
- context[GRPC_CONTEXT_SERVICE_CONFIG_CALL_DATA].value);
2150
- if (svc_cfg_call_data == nullptr) return nullptr;
2151
- return static_cast<const RetryMethodConfig*>(
2152
- svc_cfg_call_data->GetMethodParsedConfig(service_config_parser_index_));
2153
- }
2154
-
2155
- RetryFilter::CallData::CallData(RetryFilter* chand,
2156
- const grpc_call_element_args& args)
2157
- : chand_(chand),
2158
- retry_throttle_data_(chand->retry_throttle_data_),
2159
- retry_policy_(chand->GetRetryPolicy(args.context)),
2160
- retry_backoff_(
2161
- BackOff::Options()
2162
- .set_initial_backoff(retry_policy_ == nullptr
2163
- ? Duration::Zero()
2164
- : retry_policy_->initial_backoff())
2165
- .set_multiplier(retry_policy_ == nullptr
2166
- ? 0
2167
- : retry_policy_->backoff_multiplier())
2168
- .set_jitter(RETRY_BACKOFF_JITTER)
2169
- .set_max_backoff(retry_policy_ == nullptr
2170
- ? Duration::Zero()
2171
- : retry_policy_->max_backoff())),
2172
- path_(grpc_slice_ref_internal(args.path)),
2173
- deadline_(args.deadline),
2174
- arena_(args.arena),
2175
- owning_call_(args.call_stack),
2176
- call_combiner_(args.call_combiner),
2177
- call_context_(args.context),
2178
- call_stack_destruction_barrier_(
2179
- arena_->New<CallStackDestructionBarrier>()),
2180
- pending_send_initial_metadata_(false),
2181
- pending_send_message_(false),
2182
- pending_send_trailing_metadata_(false),
2183
- retry_committed_(false),
2184
- retry_timer_pending_(false),
2185
- retry_codepath_started_(false),
2186
- sent_transparent_retry_not_seen_by_server_(false) {}
2187
-
2188
- RetryFilter::CallData::~CallData() {
2189
- FreeAllCachedSendOpData();
2190
- grpc_slice_unref_internal(path_);
2191
- // Make sure there are no remaining pending batches.
2192
- for (size_t i = 0; i < GPR_ARRAY_SIZE(pending_batches_); ++i) {
2193
- GPR_ASSERT(pending_batches_[i].batch == nullptr);
2194
- }
2195
- GRPC_ERROR_UNREF(cancelled_from_surface_);
2196
- }
2197
-
2198
- void RetryFilter::CallData::StartTransportStreamOpBatch(
2199
- grpc_transport_stream_op_batch* batch) {
2200
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace) &&
2201
- !GRPC_TRACE_FLAG_ENABLED(grpc_trace_channel)) {
2202
- gpr_log(GPR_INFO, "chand=%p calld=%p: batch started from surface: %s",
2203
- chand_, this, grpc_transport_stream_op_batch_string(batch).c_str());
2204
- }
2205
- // If we have an LB call, delegate to the LB call.
2206
- if (committed_call_ != nullptr) {
2207
- // Note: This will release the call combiner.
2208
- committed_call_->StartTransportStreamOpBatch(batch);
2209
- return;
2210
- }
2211
- // If we were previously cancelled from the surface, fail this
2212
- // batch immediately.
2213
- if (!GRPC_ERROR_IS_NONE(cancelled_from_surface_)) {
2214
- // Note: This will release the call combiner.
2215
- grpc_transport_stream_op_batch_finish_with_failure(
2216
- batch, GRPC_ERROR_REF(cancelled_from_surface_), call_combiner_);
2217
- return;
2218
- }
2219
- // Handle cancellation.
2220
- if (GPR_UNLIKELY(batch->cancel_stream)) {
2221
- // Save cancel_error in case subsequent batches are started.
2222
- GRPC_ERROR_UNREF(cancelled_from_surface_);
2223
- cancelled_from_surface_ =
2224
- GRPC_ERROR_REF(batch->payload->cancel_stream.cancel_error);
2225
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2226
- gpr_log(GPR_INFO, "chand=%p calld=%p: cancelled from surface: %s", chand_,
2227
- this, grpc_error_std_string(cancelled_from_surface_).c_str());
2228
- }
2229
- // Fail any pending batches.
2230
- PendingBatchesFail(GRPC_ERROR_REF(cancelled_from_surface_));
2231
- // If we have a current call attempt, commit the call, then send
2232
- // the cancellation down to that attempt. When the call fails, it
2233
- // will not be retried, because we have committed it here.
2234
- if (call_attempt_ != nullptr) {
2235
- RetryCommit(call_attempt_.get());
2236
- // TODO(roth): When implementing hedging, this will get more
2237
- // complex, because instead of just passing the batch down to a
2238
- // single call attempt, we'll need to cancel multiple call
2239
- // attempts and wait for the cancellation on_complete from each call
2240
- // attempt before we propagate the on_complete from this batch
2241
- // back to the surface.
2242
- // Note: This will release the call combiner.
2243
- call_attempt_->CancelFromSurface(batch);
2244
- return;
2245
- }
2246
- // Cancel retry timer if needed.
2247
- if (retry_timer_pending_) {
2248
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2249
- gpr_log(GPR_INFO, "chand=%p calld=%p: cancelling retry timer", chand_,
2250
- this);
2251
- }
2252
- retry_timer_pending_ = false; // Lame timer callback.
2253
- grpc_timer_cancel(&retry_timer_);
2254
- FreeAllCachedSendOpData();
2255
- }
2256
- // We have no call attempt, so there's nowhere to send the cancellation
2257
- // batch. Return it back to the surface immediately.
2258
- // Note: This will release the call combiner.
2259
- grpc_transport_stream_op_batch_finish_with_failure(
2260
- batch, GRPC_ERROR_REF(cancelled_from_surface_), call_combiner_);
2261
- return;
2262
- }
2263
- // Add the batch to the pending list.
2264
- PendingBatch* pending = PendingBatchesAdd(batch);
2265
- // If the timer is pending, yield the call combiner and wait for it to
2266
- // run, since we don't want to start another call attempt until it does.
2267
- if (retry_timer_pending_) {
2268
- GRPC_CALL_COMBINER_STOP(call_combiner_,
2269
- "added pending batch while retry timer pending");
2270
- return;
2271
- }
2272
- // If we do not yet have a call attempt, create one.
2273
- if (call_attempt_ == nullptr) {
2274
- // If this is the first batch and retries are already committed
2275
- // (e.g., if this batch put the call above the buffer size limit), then
2276
- // immediately create an LB call and delegate the batch to it. This
2277
- // avoids the overhead of unnecessarily allocating a CallAttempt
2278
- // object or caching any of the send op data.
2279
- // Note that we would ideally like to do this also on subsequent
2280
- // attempts (e.g., if a batch puts the call above the buffer size
2281
- // limit since the last attempt was complete), but in practice that's
2282
- // not really worthwhile, because we will almost always have cached and
2283
- // completed at least the send_initial_metadata op on the previous
2284
- // attempt, which means that we'd need special logic to replay the
2285
- // batch anyway, which is exactly what the CallAttempt object provides.
2286
- // We also skip this optimization if perAttemptRecvTimeout is set in the
2287
- // retry policy, because we need the code in CallAttempt to handle
2288
- // the associated timer.
2289
- if (!retry_codepath_started_ && retry_committed_ &&
2290
- (retry_policy_ == nullptr ||
2291
- !retry_policy_->per_attempt_recv_timeout().has_value())) {
2292
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2293
- gpr_log(GPR_INFO,
2294
- "chand=%p calld=%p: retry committed before first attempt; "
2295
- "creating LB call",
2296
- chand_, this);
2297
- }
2298
- PendingBatchClear(pending);
2299
- auto* service_config_call_data =
2300
- static_cast<ClientChannelServiceConfigCallData*>(
2301
- call_context_[GRPC_CONTEXT_SERVICE_CONFIG_CALL_DATA].value);
2302
- committed_call_ = CreateLoadBalancedCall(
2303
- service_config_call_data->call_dispatch_controller(),
2304
- /*is_transparent_retry=*/false);
2305
- committed_call_->StartTransportStreamOpBatch(batch);
2306
- return;
2307
- }
2308
- // Otherwise, create a call attempt.
2309
- // The attempt will automatically start any necessary replays or
2310
- // pending batches.
2311
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2312
- gpr_log(GPR_INFO, "chand=%p calld=%p: creating call attempt", chand_,
2313
- this);
2314
- }
2315
- retry_codepath_started_ = true;
2316
- CreateCallAttempt(/*is_transparent_retry=*/false);
2317
- return;
2318
- }
2319
- // Send batches to call attempt.
2320
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2321
- gpr_log(GPR_INFO, "chand=%p calld=%p: starting batch on attempt=%p", chand_,
2322
- this, call_attempt_.get());
2323
- }
2324
- call_attempt_->StartRetriableBatches();
2325
- }
2326
-
2327
- OrphanablePtr<ClientChannel::LoadBalancedCall>
2328
- RetryFilter::CallData::CreateLoadBalancedCall(
2329
- ConfigSelector::CallDispatchController* call_dispatch_controller,
2330
- bool is_transparent_retry) {
2331
- grpc_call_element_args args = {owning_call_, nullptr, call_context_,
2332
- path_, /*start_time=*/0, deadline_,
2333
- arena_, call_combiner_};
2334
- return chand_->client_channel_->CreateLoadBalancedCall(
2335
- args, pollent_,
2336
- // This callback holds a ref to the CallStackDestructionBarrier
2337
- // object until the LB call is destroyed.
2338
- call_stack_destruction_barrier_->MakeLbCallDestructionClosure(this),
2339
- call_dispatch_controller, is_transparent_retry);
2340
- }
2341
-
2342
- void RetryFilter::CallData::CreateCallAttempt(bool is_transparent_retry) {
2343
- call_attempt_ = MakeRefCounted<CallAttempt>(this, is_transparent_retry);
2344
- call_attempt_->StartRetriableBatches();
2345
- }
2346
-
2347
- //
2348
- // send op data caching
2349
- //
2350
-
2351
- void RetryFilter::CallData::MaybeCacheSendOpsForBatch(PendingBatch* pending) {
2352
- if (pending->send_ops_cached) return;
2353
- pending->send_ops_cached = true;
2354
- grpc_transport_stream_op_batch* batch = pending->batch;
2355
- // Save a copy of metadata for send_initial_metadata ops.
2356
- if (batch->send_initial_metadata) {
2357
- seen_send_initial_metadata_ = true;
2358
- grpc_metadata_batch* send_initial_metadata =
2359
- batch->payload->send_initial_metadata.send_initial_metadata;
2360
- send_initial_metadata_ = send_initial_metadata->Copy();
2361
- peer_string_ = batch->payload->send_initial_metadata.peer_string;
2362
- }
2363
- // Set up cache for send_message ops.
2364
- if (batch->send_message) {
2365
- SliceBuffer* cache = arena_->New<SliceBuffer>(std::move(
2366
- *std::exchange(batch->payload->send_message.send_message, nullptr)));
2367
- send_messages_.push_back({cache, batch->payload->send_message.flags});
2368
- }
2369
- // Save metadata batch for send_trailing_metadata ops.
2370
- if (batch->send_trailing_metadata) {
2371
- seen_send_trailing_metadata_ = true;
2372
- grpc_metadata_batch* send_trailing_metadata =
2373
- batch->payload->send_trailing_metadata.send_trailing_metadata;
2374
- send_trailing_metadata_ = send_trailing_metadata->Copy();
2375
- }
2376
- }
2377
-
2378
- void RetryFilter::CallData::FreeCachedSendInitialMetadata() {
2379
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2380
- gpr_log(GPR_INFO, "chand=%p calld=%p: destroying send_initial_metadata",
2381
- chand_, this);
2382
- }
2383
- send_initial_metadata_.Clear();
2384
- }
2385
-
2386
- void RetryFilter::CallData::FreeCachedSendMessage(size_t idx) {
2387
- if (send_messages_[idx].slices != nullptr) {
2388
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2389
- gpr_log(GPR_INFO,
2390
- "chand=%p calld=%p: destroying send_messages[%" PRIuPTR "]",
2391
- chand_, this, idx);
2392
- }
2393
- Destruct(std::exchange(send_messages_[idx].slices, nullptr));
2394
- }
2395
- }
2396
-
2397
- void RetryFilter::CallData::FreeCachedSendTrailingMetadata() {
2398
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2399
- gpr_log(GPR_INFO, "chand=%p calld=%p: destroying send_trailing_metadata",
2400
- chand_, this);
2401
- }
2402
- send_trailing_metadata_.Clear();
2403
- }
2404
-
2405
- void RetryFilter::CallData::FreeAllCachedSendOpData() {
2406
- if (seen_send_initial_metadata_) {
2407
- FreeCachedSendInitialMetadata();
2408
- }
2409
- for (size_t i = 0; i < send_messages_.size(); ++i) {
2410
- FreeCachedSendMessage(i);
2411
- }
2412
- if (seen_send_trailing_metadata_) {
2413
- FreeCachedSendTrailingMetadata();
2414
- }
2415
- }
2416
-
2417
- //
2418
- // pending_batches management
2419
- //
2420
-
2421
- size_t RetryFilter::CallData::GetBatchIndex(
2422
- grpc_transport_stream_op_batch* batch) {
2423
- if (batch->send_initial_metadata) return 0;
2424
- if (batch->send_message) return 1;
2425
- if (batch->send_trailing_metadata) return 2;
2426
- if (batch->recv_initial_metadata) return 3;
2427
- if (batch->recv_message) return 4;
2428
- if (batch->recv_trailing_metadata) return 5;
2429
- GPR_UNREACHABLE_CODE(return (size_t)-1);
2430
- }
2431
-
2432
- // This is called via the call combiner, so access to calld is synchronized.
2433
- RetryFilter::CallData::PendingBatch* RetryFilter::CallData::PendingBatchesAdd(
2434
- grpc_transport_stream_op_batch* batch) {
2435
- const size_t idx = GetBatchIndex(batch);
2436
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2437
- gpr_log(GPR_INFO,
2438
- "chand=%p calld=%p: adding pending batch at index %" PRIuPTR,
2439
- chand_, this, idx);
2440
- }
2441
- PendingBatch* pending = &pending_batches_[idx];
2442
- GPR_ASSERT(pending->batch == nullptr);
2443
- pending->batch = batch;
2444
- pending->send_ops_cached = false;
2445
- // Update state in calld about pending batches.
2446
- // Also check if the batch takes us over the retry buffer limit.
2447
- // Note: We don't check the size of trailing metadata here, because
2448
- // gRPC clients do not send trailing metadata.
2449
- if (batch->send_initial_metadata) {
2450
- pending_send_initial_metadata_ = true;
2451
- bytes_buffered_for_retry_ += batch->payload->send_initial_metadata
2452
- .send_initial_metadata->TransportSize();
2453
- }
2454
- if (batch->send_message) {
2455
- pending_send_message_ = true;
2456
- bytes_buffered_for_retry_ +=
2457
- batch->payload->send_message.send_message->Length();
2458
- }
2459
- if (batch->send_trailing_metadata) {
2460
- pending_send_trailing_metadata_ = true;
2461
- }
2462
- // TODO(roth): When we implement hedging, if there are currently attempts
2463
- // in flight, we will need to pick the one on which the max number of send
2464
- // ops have already been sent, and we commit to that attempt.
2465
- if (GPR_UNLIKELY(bytes_buffered_for_retry_ >
2466
- chand_->per_rpc_retry_buffer_size_)) {
2467
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2468
- gpr_log(GPR_INFO,
2469
- "chand=%p calld=%p: exceeded retry buffer size, committing",
2470
- chand_, this);
2471
- }
2472
- RetryCommit(call_attempt_.get());
2473
- }
2474
- return pending;
2475
- }
2476
-
2477
- void RetryFilter::CallData::PendingBatchClear(PendingBatch* pending) {
2478
- if (pending->batch->send_initial_metadata) {
2479
- pending_send_initial_metadata_ = false;
2480
- }
2481
- if (pending->batch->send_message) {
2482
- pending_send_message_ = false;
2483
- }
2484
- if (pending->batch->send_trailing_metadata) {
2485
- pending_send_trailing_metadata_ = false;
2486
- }
2487
- pending->batch = nullptr;
2488
- }
2489
-
2490
- void RetryFilter::CallData::MaybeClearPendingBatch(PendingBatch* pending) {
2491
- grpc_transport_stream_op_batch* batch = pending->batch;
2492
- // We clear the pending batch if all of its callbacks have been
2493
- // scheduled and reset to nullptr.
2494
- if (batch->on_complete == nullptr &&
2495
- (!batch->recv_initial_metadata ||
2496
- batch->payload->recv_initial_metadata.recv_initial_metadata_ready ==
2497
- nullptr) &&
2498
- (!batch->recv_message ||
2499
- batch->payload->recv_message.recv_message_ready == nullptr) &&
2500
- (!batch->recv_trailing_metadata ||
2501
- batch->payload->recv_trailing_metadata.recv_trailing_metadata_ready ==
2502
- nullptr)) {
2503
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2504
- gpr_log(GPR_INFO, "chand=%p calld=%p: clearing pending batch", chand_,
2505
- this);
2506
- }
2507
- PendingBatchClear(pending);
2508
- }
2509
- }
2510
-
2511
- // This is called via the call combiner, so access to calld is synchronized.
2512
- void RetryFilter::CallData::FailPendingBatchInCallCombiner(
2513
- void* arg, grpc_error_handle error) {
2514
- grpc_transport_stream_op_batch* batch =
2515
- static_cast<grpc_transport_stream_op_batch*>(arg);
2516
- CallData* call = static_cast<CallData*>(batch->handler_private.extra_arg);
2517
- // Note: This will release the call combiner.
2518
- grpc_transport_stream_op_batch_finish_with_failure(
2519
- batch, GRPC_ERROR_REF(error), call->call_combiner_);
2520
- }
2521
-
2522
- // This is called via the call combiner, so access to calld is synchronized.
2523
- void RetryFilter::CallData::PendingBatchesFail(grpc_error_handle error) {
2524
- GPR_ASSERT(!GRPC_ERROR_IS_NONE(error));
2525
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2526
- size_t num_batches = 0;
2527
- for (size_t i = 0; i < GPR_ARRAY_SIZE(pending_batches_); ++i) {
2528
- if (pending_batches_[i].batch != nullptr) ++num_batches;
2529
- }
2530
- gpr_log(GPR_INFO,
2531
- "chand=%p calld=%p: failing %" PRIuPTR " pending batches: %s",
2532
- chand_, this, num_batches, grpc_error_std_string(error).c_str());
2533
- }
2534
- CallCombinerClosureList closures;
2535
- for (size_t i = 0; i < GPR_ARRAY_SIZE(pending_batches_); ++i) {
2536
- PendingBatch* pending = &pending_batches_[i];
2537
- grpc_transport_stream_op_batch* batch = pending->batch;
2538
- if (batch != nullptr) {
2539
- batch->handler_private.extra_arg = this;
2540
- GRPC_CLOSURE_INIT(&batch->handler_private.closure,
2541
- FailPendingBatchInCallCombiner, batch,
2542
- grpc_schedule_on_exec_ctx);
2543
- closures.Add(&batch->handler_private.closure, GRPC_ERROR_REF(error),
2544
- "PendingBatchesFail");
2545
- PendingBatchClear(pending);
2546
- }
2547
- }
2548
- closures.RunClosuresWithoutYielding(call_combiner_);
2549
- GRPC_ERROR_UNREF(error);
2550
- }
2551
-
2552
- template <typename Predicate>
2553
- RetryFilter::CallData::PendingBatch* RetryFilter::CallData::PendingBatchFind(
2554
- const char* log_message, Predicate predicate) {
2555
- for (size_t i = 0; i < GPR_ARRAY_SIZE(pending_batches_); ++i) {
2556
- PendingBatch* pending = &pending_batches_[i];
2557
- grpc_transport_stream_op_batch* batch = pending->batch;
2558
- if (batch != nullptr && predicate(batch)) {
2559
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2560
- gpr_log(GPR_INFO,
2561
- "chand=%p calld=%p: %s pending batch at index %" PRIuPTR,
2562
- chand_, this, log_message, i);
2563
- }
2564
- return pending;
2565
- }
2566
- }
2567
- return nullptr;
2568
- }
2569
-
2570
- //
2571
- // retry code
2572
- //
2573
-
2574
- void RetryFilter::CallData::RetryCommit(CallAttempt* call_attempt) {
2575
- if (retry_committed_) return;
2576
- retry_committed_ = true;
2577
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2578
- gpr_log(GPR_INFO, "chand=%p calld=%p: committing retries", chand_, this);
2579
- }
2580
- if (call_attempt != nullptr) {
2581
- // If the call attempt's LB call has been committed, inform the call
2582
- // dispatch controller that the call has been committed.
2583
- // Note: If call_attempt is null, this is happening before the first
2584
- // retry attempt is started, in which case we'll just pass the real
2585
- // call dispatch controller down into the LB call, and it won't be
2586
- // our problem anymore.
2587
- if (call_attempt->lb_call_committed()) {
2588
- auto* service_config_call_data =
2589
- static_cast<ClientChannelServiceConfigCallData*>(
2590
- call_context_[GRPC_CONTEXT_SERVICE_CONFIG_CALL_DATA].value);
2591
- service_config_call_data->call_dispatch_controller()->Commit();
2592
- }
2593
- // Free cached send ops.
2594
- call_attempt->FreeCachedSendOpDataAfterCommit();
2595
- }
2596
- }
2597
-
2598
- void RetryFilter::CallData::StartRetryTimer(
2599
- absl::optional<Duration> server_pushback) {
2600
- // Reset call attempt.
2601
- call_attempt_.reset(DEBUG_LOCATION, "StartRetryTimer");
2602
- // Compute backoff delay.
2603
- Timestamp next_attempt_time;
2604
- if (server_pushback.has_value()) {
2605
- GPR_ASSERT(*server_pushback >= Duration::Zero());
2606
- next_attempt_time = Timestamp::Now() + *server_pushback;
2607
- retry_backoff_.Reset();
2608
- } else {
2609
- next_attempt_time = retry_backoff_.NextAttemptTime();
2610
- }
2611
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2612
- gpr_log(GPR_INFO,
2613
- "chand=%p calld=%p: retrying failed call in %" PRId64 " ms", chand_,
2614
- this, (next_attempt_time - Timestamp::Now()).millis());
2615
- }
2616
- // Schedule retry after computed delay.
2617
- GRPC_CLOSURE_INIT(&retry_closure_, OnRetryTimer, this, nullptr);
2618
- GRPC_CALL_STACK_REF(owning_call_, "OnRetryTimer");
2619
- retry_timer_pending_ = true;
2620
- grpc_timer_init(&retry_timer_, next_attempt_time, &retry_closure_);
2621
- }
2622
-
2623
- void RetryFilter::CallData::OnRetryTimer(void* arg, grpc_error_handle error) {
2624
- auto* calld = static_cast<CallData*>(arg);
2625
- GRPC_CLOSURE_INIT(&calld->retry_closure_, OnRetryTimerLocked, calld, nullptr);
2626
- GRPC_CALL_COMBINER_START(calld->call_combiner_, &calld->retry_closure_,
2627
- GRPC_ERROR_REF(error), "retry timer fired");
2628
- }
2629
-
2630
- void RetryFilter::CallData::OnRetryTimerLocked(void* arg,
2631
- grpc_error_handle error) {
2632
- auto* calld = static_cast<CallData*>(arg);
2633
- if (GRPC_ERROR_IS_NONE(error) && calld->retry_timer_pending_) {
2634
- calld->retry_timer_pending_ = false;
2635
- calld->CreateCallAttempt(/*is_transparent_retry=*/false);
2636
- } else {
2637
- GRPC_CALL_COMBINER_STOP(calld->call_combiner_, "retry timer cancelled");
2638
- }
2639
- GRPC_CALL_STACK_UNREF(calld->owning_call_, "OnRetryTimer");
2640
- }
2641
-
2642
- void RetryFilter::CallData::AddClosureToStartTransparentRetry(
2643
- CallCombinerClosureList* closures) {
2644
- if (GRPC_TRACE_FLAG_ENABLED(grpc_retry_trace)) {
2645
- gpr_log(GPR_INFO, "chand=%p calld=%p: scheduling transparent retry", chand_,
2646
- this);
2647
- }
2648
- GRPC_CALL_STACK_REF(owning_call_, "OnRetryTimer");
2649
- GRPC_CLOSURE_INIT(&retry_closure_, StartTransparentRetry, this, nullptr);
2650
- closures->Add(&retry_closure_, GRPC_ERROR_NONE, "start transparent retry");
2651
- }
2652
-
2653
- void RetryFilter::CallData::StartTransparentRetry(void* arg,
2654
- grpc_error_handle /*error*/) {
2655
- auto* calld = static_cast<CallData*>(arg);
2656
- if (GRPC_ERROR_IS_NONE(calld->cancelled_from_surface_)) {
2657
- calld->CreateCallAttempt(/*is_transparent_retry=*/true);
2658
- } else {
2659
- GRPC_CALL_COMBINER_STOP(calld->call_combiner_,
2660
- "call cancelled before transparent retry");
2661
- }
2662
- GRPC_CALL_STACK_UNREF(calld->owning_call_, "OnRetryTimer");
2663
- }
2664
-
2665
- } // namespace
2666
-
2667
- const grpc_channel_filter kRetryFilterVtable = {
2668
- RetryFilter::CallData::StartTransportStreamOpBatch,
2669
- nullptr,
2670
- RetryFilter::StartTransportOp,
2671
- sizeof(RetryFilter::CallData),
2672
- RetryFilter::CallData::Init,
2673
- RetryFilter::CallData::SetPollent,
2674
- RetryFilter::CallData::Destroy,
2675
- sizeof(RetryFilter),
2676
- RetryFilter::Init,
2677
- grpc_channel_stack_no_post_init,
2678
- RetryFilter::Destroy,
2679
- RetryFilter::GetChannelInfo,
2680
- "retry_filter",
2681
- };
2682
-
2683
- } // namespace grpc_core