grpc 1.30.2 → 1.32.0
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.
- checksums.yaml +4 -4
- data/Makefile +723 -15910
- data/include/grpc/grpc_security.h +31 -14
- data/include/grpc/grpc_security_constants.h +3 -0
- data/include/grpc/impl/codegen/README.md +22 -0
- data/include/grpc/impl/codegen/grpc_types.h +7 -5
- data/include/grpc/impl/codegen/port_platform.h +6 -33
- data/src/core/ext/filters/client_channel/backend_metric.cc +12 -9
- data/src/core/ext/filters/client_channel/backup_poller.cc +3 -2
- data/src/core/ext/filters/client_channel/client_channel.cc +470 -285
- data/src/core/ext/filters/client_channel/client_channel.h +1 -1
- data/src/core/ext/filters/client_channel/client_channel_channelz.h +0 -3
- data/src/core/ext/filters/client_channel/config_selector.cc +62 -0
- data/src/core/ext/filters/client_channel/config_selector.h +93 -0
- data/src/core/ext/filters/client_channel/global_subchannel_pool.cc +24 -2
- data/src/core/ext/filters/client_channel/health/health_check_client.cc +8 -1
- data/src/core/ext/filters/client_channel/http_connect_handshaker.cc +8 -8
- data/src/core/ext/filters/client_channel/http_proxy.cc +6 -4
- data/src/core/ext/filters/client_channel/lb_policy.h +4 -0
- data/src/core/ext/filters/client_channel/lb_policy/child_policy_handler.cc +6 -4
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb.cc +59 -36
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.cc +0 -13
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_balancer_addresses.h +0 -3
- data/src/core/ext/filters/client_channel/lb_policy/grpclb/grpclb_channel_secure.cc +1 -37
- data/src/core/ext/filters/client_channel/lb_policy/pick_first/pick_first.cc +19 -13
- data/src/core/ext/filters/client_channel/lb_policy/priority/priority.cc +29 -10
- data/src/core/ext/filters/client_channel/lb_policy/round_robin/round_robin.cc +5 -4
- data/src/core/ext/filters/client_channel/lb_policy/subchannel_list.h +4 -6
- data/src/core/ext/filters/client_channel/lb_policy/weighted_target/weighted_target.cc +23 -13
- data/src/core/ext/filters/client_channel/lb_policy/xds/cds.cc +18 -12
- data/src/core/ext/filters/client_channel/lb_policy/xds/eds.cc +22 -14
- data/src/core/ext/filters/client_channel/lb_policy/xds/lrs.cc +18 -9
- data/src/core/ext/filters/client_channel/lb_policy/xds/xds_routing.cc +385 -78
- data/src/core/ext/filters/client_channel/lb_policy_registry.cc +4 -5
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/dns_resolver_ares.cc +5 -2
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver.cc +6 -5
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_libuv.cc +8 -6
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_posix.cc +9 -7
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_ev_driver_windows.cc +7 -5
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper.cc +36 -51
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_libuv.cc +1 -1
- data/src/core/ext/filters/client_channel/resolver/dns/c_ares/grpc_ares_wrapper_windows.cc +1 -1
- data/src/core/ext/filters/client_channel/resolver/dns/native/dns_resolver.cc +6 -2
- data/src/core/ext/filters/client_channel/resolver/fake/fake_resolver.cc +1 -1
- data/src/core/ext/filters/client_channel/resolver/sockaddr/sockaddr_resolver.cc +1 -1
- data/src/core/ext/filters/client_channel/resolver/xds/xds_resolver.cc +383 -31
- data/src/core/ext/filters/client_channel/resolver_registry.cc +13 -14
- data/src/core/ext/filters/client_channel/resolver_result_parsing.cc +6 -7
- data/src/core/ext/filters/client_channel/resolver_result_parsing.h +0 -1
- data/src/core/ext/filters/client_channel/resolving_lb_policy.cc +38 -32
- data/src/core/ext/filters/client_channel/resolving_lb_policy.h +39 -20
- data/src/core/ext/filters/client_channel/server_address.cc +40 -7
- data/src/core/ext/filters/client_channel/server_address.h +42 -4
- data/src/core/ext/filters/client_channel/service_config_channel_arg_filter.cc +142 -0
- data/src/core/ext/filters/client_channel/subchannel.cc +65 -24
- data/src/core/ext/filters/client_channel/subchannel.h +16 -4
- data/src/core/ext/filters/http/client/http_client_filter.cc +5 -5
- data/src/core/ext/filters/http/http_filters_plugin.cc +2 -1
- data/src/core/ext/filters/http/message_compress/message_decompress_filter.cc +74 -33
- data/src/core/ext/filters/http/message_compress/message_decompress_filter.h +3 -1
- data/src/core/ext/filters/max_age/max_age_filter.cc +2 -1
- data/src/core/ext/filters/message_size/message_size_filter.cc +56 -80
- data/src/core/ext/filters/message_size/message_size_filter.h +6 -0
- data/src/core/ext/transport/chttp2/client/chttp2_connector.cc +87 -31
- data/src/core/ext/transport/chttp2/client/chttp2_connector.h +18 -1
- data/src/core/ext/transport/chttp2/client/secure/secure_channel_create.cc +10 -35
- data/src/core/ext/transport/chttp2/server/chttp2_server.cc +378 -348
- data/src/core/ext/transport/chttp2/server/chttp2_server.h +7 -2
- data/src/core/ext/transport/chttp2/server/insecure/server_chttp2.cc +3 -3
- data/src/core/ext/transport/chttp2/server/insecure/server_chttp2_posix.cc +10 -16
- data/src/core/ext/transport/chttp2/server/secure/server_secure_chttp2.cc +9 -9
- data/src/core/ext/transport/chttp2/transport/chttp2_transport.cc +256 -279
- data/src/core/ext/transport/chttp2/transport/flow_control.cc +23 -28
- data/src/core/ext/transport/chttp2/transport/flow_control.h +14 -16
- data/src/core/ext/transport/chttp2/transport/frame_data.cc +9 -12
- data/src/core/ext/transport/chttp2/transport/frame_goaway.cc +4 -6
- data/src/core/ext/transport/chttp2/transport/frame_ping.cc +5 -6
- data/src/core/ext/transport/chttp2/transport/frame_rst_stream.cc +12 -13
- data/src/core/ext/transport/chttp2/transport/frame_settings.cc +8 -9
- data/src/core/ext/transport/chttp2/transport/frame_window_update.cc +9 -12
- data/src/core/ext/transport/chttp2/transport/hpack_parser.cc +25 -29
- data/src/core/ext/transport/chttp2/transport/hpack_table.cc +13 -17
- data/src/core/ext/transport/chttp2/transport/internal.h +18 -1
- data/src/core/ext/transport/chttp2/transport/parsing.cc +34 -71
- data/src/core/ext/transport/chttp2/transport/writing.cc +15 -19
- data/src/core/ext/transport/inproc/inproc_transport.cc +47 -27
- data/src/core/ext/upb-generated/envoy/annotations/deprecation.upb.h +0 -1
- data/src/core/ext/upb-generated/envoy/annotations/resource.upb.h +3 -4
- data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.c +224 -0
- data/src/core/ext/upb-generated/envoy/config/accesslog/v3/accesslog.upb.h +700 -0
- data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.c +74 -0
- data/src/core/ext/upb-generated/envoy/config/cluster/v3/circuit_breaker.upb.h +226 -0
- data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.c +380 -0
- data/src/core/ext/upb-generated/envoy/config/cluster/v3/cluster.upb.h +1378 -0
- data/src/core/ext/upb-generated/envoy/{api/v2/cluster → config/cluster/v3}/filter.upb.c +8 -8
- data/src/core/ext/upb-generated/envoy/config/cluster/v3/filter.upb.h +69 -0
- data/src/core/ext/upb-generated/envoy/{api/v2/cluster → config/cluster/v3}/outlier_detection.upb.c +8 -8
- data/src/core/ext/upb-generated/envoy/config/cluster/v3/outlier_detection.upb.h +323 -0
- data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.c +112 -0
- data/src/core/ext/upb-generated/envoy/config/core/v3/address.upb.h +334 -0
- data/src/core/ext/upb-generated/envoy/{api/v2/core → config/core/v3}/backoff.upb.c +8 -8
- data/src/core/ext/upb-generated/envoy/config/core/v3/backoff.upb.h +79 -0
- data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.c +309 -0
- data/src/core/ext/upb-generated/envoy/config/core/v3/base.upb.h +869 -0
- data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.c +96 -0
- data/src/core/ext/upb-generated/envoy/config/core/v3/config_source.upb.h +328 -0
- data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.c +34 -0
- data/src/core/ext/upb-generated/envoy/config/core/v3/event_service_config.upb.h +71 -0
- data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.c +195 -0
- data/src/core/ext/upb-generated/envoy/config/core/v3/grpc_service.upb.h +634 -0
- data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.c +170 -0
- data/src/core/ext/upb-generated/envoy/config/core/v3/health_check.upb.h +684 -0
- data/src/core/ext/upb-generated/envoy/{api/v2/core → config/core/v3}/http_uri.upb.c +8 -8
- data/src/core/ext/upb-generated/envoy/config/core/v3/http_uri.upb.h +80 -0
- data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.c +152 -0
- data/src/core/ext/upb-generated/envoy/config/core/v3/protocol.upb.h +536 -0
- data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.c +28 -0
- data/src/core/ext/upb-generated/envoy/config/core/v3/proxy_protocol.upb.h +58 -0
- data/src/core/ext/upb-generated/envoy/{api/v2/core → config/core/v3}/socket_option.upb.c +6 -6
- data/src/core/ext/upb-generated/envoy/config/core/v3/socket_option.upb.h +88 -0
- data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.c +91 -0
- data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint.upb.h +220 -0
- data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.c +91 -0
- data/src/core/ext/upb-generated/envoy/config/endpoint/v3/endpoint_components.upb.h +273 -0
- data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.c +112 -0
- data/src/core/ext/upb-generated/envoy/config/endpoint/v3/load_report.upb.h +332 -0
- data/src/core/ext/upb-generated/envoy/config/listener/{v2 → v3}/api_listener.upb.c +8 -8
- data/src/core/ext/upb-generated/envoy/config/listener/v3/api_listener.upb.h +65 -0
- data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.c +108 -0
- data/src/core/ext/upb-generated/envoy/config/listener/v3/listener.upb.h +401 -0
- data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.c +138 -0
- data/src/core/ext/upb-generated/envoy/config/listener/v3/listener_components.upb.h +490 -0
- data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.c +41 -0
- data/src/core/ext/upb-generated/envoy/config/listener/v3/udp_listener_config.upb.h +94 -0
- data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.c +174 -0
- data/src/core/ext/upb-generated/envoy/config/rbac/v3/rbac.upb.h +599 -0
- data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.c +63 -0
- data/src/core/ext/upb-generated/envoy/config/route/v3/route.upb.h +204 -0
- data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.c +773 -0
- data/src/core/ext/upb-generated/envoy/config/route/v3/route_components.upb.h +2855 -0
- data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.c +59 -0
- data/src/core/ext/upb-generated/envoy/config/route/v3/scoped_route.upb.h +135 -0
- data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.c +50 -0
- data/src/core/ext/upb-generated/envoy/config/trace/v3/http_tracer.upb.h +108 -0
- data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.c +312 -0
- data/src/core/ext/upb-generated/envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.upb.h +1125 -0
- data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.c +20 -0
- data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/cert.upb.h +34 -0
- data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.c +111 -0
- data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/common.upb.h +401 -0
- data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.c +72 -0
- data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/secret.upb.h +198 -0
- data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.c +105 -0
- data/src/core/ext/upb-generated/envoy/extensions/transport_sockets/tls/v3/tls.upb.h +388 -0
- data/src/core/ext/upb-generated/envoy/{api/v2 → service/cluster/v3}/cds.upb.c +5 -6
- data/src/core/ext/upb-generated/envoy/service/cluster/v3/cds.upb.h +49 -0
- data/src/core/ext/upb-generated/envoy/service/discovery/{v2 → v3}/ads.upb.c +5 -4
- data/src/core/ext/upb-generated/envoy/service/discovery/v3/ads.upb.h +49 -0
- data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.c +129 -0
- data/src/core/ext/upb-generated/envoy/service/discovery/v3/discovery.upb.h +386 -0
- data/src/core/ext/upb-generated/envoy/{api/v2 → service/endpoint/v3}/eds.upb.c +5 -6
- data/src/core/ext/upb-generated/envoy/service/endpoint/v3/eds.upb.h +49 -0
- data/src/core/ext/upb-generated/envoy/{api/v2 → service/listener/v3}/lds.upb.c +5 -6
- data/src/core/ext/upb-generated/envoy/service/listener/v3/lds.upb.h +49 -0
- data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.c +55 -0
- data/src/core/ext/upb-generated/envoy/service/load_stats/v3/lrs.upb.h +136 -0
- data/src/core/ext/upb-generated/envoy/{api/v2 → service/route/v3}/rds.upb.c +5 -6
- data/src/core/ext/upb-generated/envoy/service/route/v3/rds.upb.h +49 -0
- data/src/core/ext/upb-generated/envoy/{api/v2 → service/route/v3}/srds.upb.c +5 -6
- data/src/core/ext/upb-generated/envoy/service/route/v3/srds.upb.h +49 -0
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.c +47 -0
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/metadata.upb.h +114 -0
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.c +35 -0
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/number.upb.h +77 -0
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.c +34 -0
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/path.upb.h +71 -0
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.c +64 -0
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/regex.upb.h +145 -0
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.c +53 -0
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/string.upb.h +127 -0
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.c +63 -0
- data/src/core/ext/upb-generated/envoy/type/matcher/v3/value.upb.h +188 -0
- data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.c +88 -0
- data/src/core/ext/upb-generated/envoy/type/metadata/v3/metadata.upb.h +258 -0
- data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.c +90 -0
- data/src/core/ext/upb-generated/envoy/type/tracing/v3/custom_tag.upb.h +250 -0
- data/src/core/ext/upb-generated/envoy/type/{http.upb.c → v3/http.upb.c} +2 -2
- data/src/core/ext/upb-generated/envoy/type/{http.upb.h → v3/http.upb.h} +8 -9
- data/src/core/ext/upb-generated/envoy/type/{percent.upb.c → v3/percent.upb.c} +9 -8
- data/src/core/ext/upb-generated/envoy/type/v3/percent.upb.h +86 -0
- data/src/core/ext/upb-generated/envoy/type/{range.upb.c → v3/range.upb.c} +12 -11
- data/src/core/ext/upb-generated/envoy/type/v3/range.upb.h +111 -0
- data/src/core/ext/upb-generated/envoy/type/{semantic_version.upb.c → v3/semantic_version.upb.c} +6 -5
- data/src/core/ext/upb-generated/envoy/type/v3/semantic_version.upb.h +61 -0
- data/src/core/ext/upb-generated/gogoproto/gogo.upb.h +0 -1
- data/src/core/ext/upb-generated/google/api/annotations.upb.h +0 -1
- data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.c +234 -0
- data/src/core/ext/upb-generated/google/api/expr/v1alpha1/syntax.upb.h +759 -0
- data/src/core/ext/upb-generated/google/api/http.upb.h +29 -28
- data/src/core/ext/upb-generated/google/protobuf/any.upb.h +5 -6
- data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.c +39 -39
- data/src/core/ext/upb-generated/google/protobuf/descriptor.upb.h +412 -386
- data/src/core/ext/upb-generated/google/protobuf/duration.upb.h +5 -6
- data/src/core/ext/upb-generated/google/protobuf/empty.upb.h +1 -2
- data/src/core/ext/upb-generated/google/protobuf/struct.upb.c +1 -1
- data/src/core/ext/upb-generated/google/protobuf/struct.upb.h +34 -55
- data/src/core/ext/upb-generated/google/protobuf/timestamp.upb.h +5 -6
- data/src/core/ext/upb-generated/google/protobuf/wrappers.upb.h +27 -28
- data/src/core/ext/upb-generated/google/rpc/status.upb.h +8 -8
- data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.c +1 -1
- data/src/core/ext/upb-generated/src/proto/grpc/gcp/altscontext.upb.h +32 -45
- data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.c +4 -4
- data/src/core/ext/upb-generated/src/proto/grpc/gcp/handshaker.upb.h +157 -178
- data/src/core/ext/upb-generated/src/proto/grpc/gcp/transport_security_common.upb.h +14 -13
- data/src/core/ext/upb-generated/src/proto/grpc/health/v1/health.upb.h +6 -7
- data/src/core/ext/upb-generated/src/proto/grpc/lb/v1/load_balancer.upb.h +59 -56
- data/src/core/ext/upb-generated/udpa/annotations/migrate.upb.h +11 -12
- data/src/core/ext/upb-generated/udpa/annotations/sensitive.upb.h +0 -1
- data/src/core/ext/upb-generated/udpa/annotations/status.upb.h +5 -6
- data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.c +27 -0
- data/src/core/ext/upb-generated/udpa/annotations/versioning.upb.h +53 -0
- data/src/core/ext/upb-generated/udpa/data/orca/v1/orca_load_report.upb.c +6 -6
- data/src/core/ext/upb-generated/udpa/data/orca/v1/orca_load_report.upb.h +41 -68
- data/src/core/ext/upb-generated/validate/validate.upb.c +11 -11
- data/src/core/ext/upb-generated/validate/validate.upb.h +537 -536
- data/src/core/ext/xds/xds_api.cc +2388 -0
- data/src/core/ext/{filters/client_channel/xds → xds}/xds_api.h +120 -40
- data/src/core/ext/{filters/client_channel/xds → xds}/xds_bootstrap.cc +56 -25
- data/src/core/ext/{filters/client_channel/xds → xds}/xds_bootstrap.h +8 -3
- data/src/core/ext/{filters/client_channel/xds → xds}/xds_channel.h +4 -4
- data/src/core/ext/{filters/client_channel/xds → xds}/xds_channel_args.h +3 -3
- data/src/core/ext/{filters/client_channel/xds → xds}/xds_channel_secure.cc +2 -5
- data/src/core/ext/{filters/client_channel/xds → xds}/xds_client.cc +94 -347
- data/src/core/ext/{filters/client_channel/xds → xds}/xds_client.h +12 -45
- data/src/core/ext/{filters/client_channel/xds → xds}/xds_client_stats.cc +2 -2
- data/src/core/ext/{filters/client_channel/xds → xds}/xds_client_stats.h +13 -13
- data/src/core/lib/channel/channel_trace.cc +2 -6
- data/src/core/lib/channel/channelz.cc +19 -30
- data/src/core/lib/channel/channelz.h +1 -1
- data/src/core/lib/channel/channelz_registry.cc +3 -1
- data/src/core/lib/gpr/log_linux.cc +6 -8
- data/src/core/lib/gpr/log_posix.cc +6 -8
- data/src/core/lib/gpr/string.cc +10 -9
- data/src/core/lib/gpr/string.h +4 -2
- data/src/core/lib/gpr/sync_posix.cc +2 -8
- data/src/core/lib/gprpp/global_config_env.cc +8 -6
- data/src/core/lib/http/httpcli.cc +13 -10
- data/src/core/lib/http/httpcli_security_connector.cc +5 -5
- data/src/core/lib/iomgr/cfstream_handle.cc +1 -0
- data/src/core/lib/iomgr/endpoint.cc +5 -1
- data/src/core/lib/iomgr/endpoint.h +7 -3
- data/src/core/lib/iomgr/endpoint_cfstream.cc +32 -11
- data/src/core/lib/iomgr/endpoint_pair_posix.cc +10 -10
- data/src/core/lib/iomgr/error_cfstream.cc +9 -8
- data/src/core/lib/iomgr/ev_epoll1_linux.cc +5 -6
- data/src/core/lib/iomgr/ev_epollex_linux.cc +15 -21
- data/src/core/lib/iomgr/ev_poll_posix.cc +6 -5
- data/src/core/lib/iomgr/is_epollexclusive_available.cc +14 -0
- data/src/core/{ext/filters/client_channel → lib/iomgr}/parse_address.cc +1 -1
- data/src/core/{ext/filters/client_channel → lib/iomgr}/parse_address.h +3 -3
- data/src/core/lib/iomgr/port.h +1 -21
- data/src/core/lib/iomgr/resolve_address_custom.cc +13 -18
- data/src/core/lib/iomgr/resolve_address_windows.cc +8 -8
- data/src/core/lib/iomgr/resource_quota.cc +34 -31
- data/src/core/lib/iomgr/sockaddr_utils.cc +9 -6
- data/src/core/lib/iomgr/sockaddr_utils.h +3 -2
- data/src/core/lib/iomgr/socket_utils_common_posix.cc +95 -55
- data/src/core/lib/iomgr/socket_windows.cc +4 -5
- data/src/core/lib/iomgr/tcp_client_cfstream.cc +9 -11
- data/src/core/lib/iomgr/tcp_client_custom.cc +6 -9
- data/src/core/lib/iomgr/tcp_client_posix.cc +27 -36
- data/src/core/lib/iomgr/tcp_client_windows.cc +9 -9
- data/src/core/lib/iomgr/tcp_custom.cc +33 -17
- data/src/core/lib/iomgr/tcp_custom.h +1 -1
- data/src/core/lib/iomgr/tcp_posix.cc +31 -13
- data/src/core/lib/iomgr/tcp_server.cc +3 -4
- data/src/core/lib/iomgr/tcp_server.h +7 -5
- data/src/core/lib/iomgr/tcp_server_custom.cc +6 -14
- data/src/core/lib/iomgr/tcp_server_posix.cc +34 -41
- data/src/core/lib/iomgr/tcp_server_utils_posix.h +3 -4
- data/src/core/lib/iomgr/tcp_server_utils_posix_common.cc +5 -7
- data/src/core/lib/iomgr/tcp_server_utils_posix_ifaddrs.cc +4 -9
- data/src/core/lib/iomgr/tcp_server_windows.cc +16 -16
- data/src/core/lib/iomgr/tcp_windows.cc +26 -10
- data/src/core/lib/iomgr/timer_generic.cc +13 -12
- data/src/core/lib/iomgr/udp_server.cc +24 -23
- data/src/core/lib/iomgr/udp_server.h +5 -2
- data/src/core/lib/iomgr/unix_sockets_posix.cc +9 -14
- data/src/core/lib/iomgr/unix_sockets_posix.h +3 -1
- data/src/core/lib/iomgr/unix_sockets_posix_noop.cc +5 -2
- data/src/core/lib/json/json_reader.cc +20 -21
- data/src/core/lib/security/authorization/authorization_engine.cc +177 -0
- data/src/core/lib/security/authorization/authorization_engine.h +84 -0
- data/src/core/lib/security/authorization/evaluate_args.cc +153 -0
- data/src/core/lib/security/authorization/evaluate_args.h +59 -0
- data/src/core/lib/security/authorization/mock_cel/activation.h +57 -0
- data/src/core/lib/security/authorization/mock_cel/cel_expr_builder_factory.h +42 -0
- data/src/core/lib/security/authorization/mock_cel/cel_expression.h +68 -0
- data/src/core/lib/security/authorization/mock_cel/cel_value.h +93 -0
- data/src/core/lib/security/authorization/mock_cel/evaluator_core.h +67 -0
- data/src/core/lib/security/authorization/mock_cel/flat_expr_builder.h +56 -0
- data/src/core/lib/security/authorization/mock_cel/statusor.h +50 -0
- data/src/core/lib/security/credentials/credentials.h +5 -3
- data/src/core/lib/security/credentials/google_default/credentials_generic.cc +8 -6
- data/src/core/lib/security/credentials/google_default/google_default_credentials.cc +64 -43
- data/src/core/lib/security/credentials/jwt/jwt_credentials.cc +7 -4
- data/src/core/lib/security/credentials/oauth2/oauth2_credentials.cc +19 -28
- data/src/core/lib/security/credentials/plugin/plugin_credentials.cc +6 -6
- data/src/core/lib/security/credentials/ssl/ssl_credentials.cc +20 -0
- data/src/core/lib/security/credentials/ssl/ssl_credentials.h +10 -0
- data/src/core/lib/security/credentials/tls/grpc_tls_credentials_options.h +10 -0
- data/src/core/lib/security/security_connector/fake/fake_security_connector.cc +11 -12
- data/src/core/lib/security/security_connector/security_connector.cc +2 -0
- data/src/core/lib/security/security_connector/security_connector.h +1 -1
- data/src/core/lib/security/security_connector/ssl/ssl_security_connector.cc +18 -11
- data/src/core/lib/security/security_connector/ssl/ssl_security_connector.h +5 -0
- data/src/core/lib/security/security_connector/ssl_utils.cc +44 -23
- data/src/core/lib/security/security_connector/ssl_utils.h +6 -2
- data/src/core/lib/security/security_connector/tls/tls_security_connector.cc +27 -24
- data/src/core/lib/security/transport/client_auth_filter.cc +10 -9
- data/src/core/lib/security/transport/secure_endpoint.cc +7 -1
- data/src/core/lib/security/util/json_util.cc +12 -13
- data/src/core/lib/slice/slice.cc +38 -1
- data/src/core/lib/slice/slice_internal.h +1 -0
- data/src/core/lib/surface/call.cc +52 -53
- data/src/core/lib/surface/call.h +2 -1
- data/src/core/lib/surface/channel.cc +28 -20
- data/src/core/lib/surface/channel.h +12 -2
- data/src/core/lib/surface/completion_queue.cc +0 -5
- data/src/core/lib/surface/init.cc +1 -1
- data/src/core/lib/surface/server.cc +1102 -1347
- data/src/core/lib/surface/server.h +369 -71
- data/src/core/lib/surface/version.cc +2 -2
- data/src/core/lib/transport/authority_override.cc +38 -0
- data/src/core/lib/transport/authority_override.h +32 -0
- data/src/core/lib/transport/connectivity_state.cc +18 -13
- data/src/core/lib/transport/connectivity_state.h +18 -6
- data/src/core/lib/transport/error_utils.cc +13 -0
- data/src/core/lib/transport/error_utils.h +6 -0
- data/src/core/lib/transport/static_metadata.cc +295 -276
- data/src/core/lib/transport/static_metadata.h +80 -73
- data/src/core/lib/transport/transport.h +13 -0
- data/src/core/lib/uri/uri_parser.cc +30 -35
- data/src/core/lib/uri/uri_parser.h +3 -1
- data/src/core/plugin_registry/grpc_plugin_registry.cc +4 -0
- data/src/core/tsi/alts/handshaker/alts_handshaker_client.cc +23 -13
- data/src/core/tsi/alts/handshaker/alts_tsi_handshaker.cc +24 -0
- data/src/core/tsi/alts/handshaker/transport_security_common_api.cc +2 -0
- data/src/core/tsi/ssl_transport_security.cc +102 -11
- data/src/core/tsi/ssl_transport_security.h +14 -2
- data/src/core/tsi/transport_security_interface.h +5 -0
- data/src/ruby/bin/math_services_pb.rb +4 -4
- data/src/ruby/ext/grpc/extconf.rb +5 -2
- data/src/ruby/ext/grpc/rb_call.c +3 -2
- data/src/ruby/ext/grpc/rb_call.h +4 -0
- data/src/ruby/ext/grpc/rb_call_credentials.c +54 -10
- data/src/ruby/ext/grpc/rb_channel_credentials.c +9 -0
- data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +2 -2
- data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +4 -4
- data/src/ruby/lib/grpc/generic/client_stub.rb +1 -1
- data/src/ruby/lib/grpc/generic/interceptors.rb +1 -1
- data/src/ruby/lib/grpc/version.rb +1 -1
- data/src/ruby/pb/grpc/health/v1/health_services_pb.rb +2 -2
- data/src/ruby/pb/src/proto/grpc/testing/messages_pb.rb +5 -0
- data/src/ruby/pb/src/proto/grpc/testing/test_services_pb.rb +28 -12
- data/src/ruby/spec/channel_credentials_spec.rb +10 -0
- data/src/ruby/spec/generic/active_call_spec.rb +19 -8
- data/src/ruby/spec/pb/codegen/grpc/testing/same_package_service_name.proto +27 -0
- data/src/ruby/spec/pb/codegen/grpc/testing/same_ruby_package_service_name.proto +29 -0
- data/src/ruby/spec/pb/codegen/package_option_spec.rb +20 -0
- data/src/ruby/spec/user_agent_spec.rb +74 -0
- data/third_party/abseil-cpp/absl/algorithm/container.h +1727 -0
- data/third_party/abseil-cpp/absl/base/internal/direct_mmap.h +161 -0
- data/third_party/abseil-cpp/absl/base/internal/exponential_biased.cc +93 -0
- data/third_party/abseil-cpp/absl/base/internal/exponential_biased.h +130 -0
- data/third_party/abseil-cpp/absl/base/internal/low_level_alloc.cc +620 -0
- data/third_party/abseil-cpp/absl/base/internal/low_level_alloc.h +126 -0
- data/third_party/abseil-cpp/absl/container/fixed_array.h +515 -0
- data/third_party/abseil-cpp/absl/container/flat_hash_set.h +503 -0
- data/third_party/abseil-cpp/absl/container/internal/common.h +202 -0
- data/third_party/abseil-cpp/absl/container/internal/container_memory.h +440 -0
- data/third_party/abseil-cpp/absl/container/internal/hash_function_defaults.h +146 -0
- data/third_party/abseil-cpp/absl/container/internal/hash_policy_traits.h +191 -0
- data/third_party/abseil-cpp/absl/container/internal/hashtable_debug_hooks.h +85 -0
- data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.cc +269 -0
- data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler.h +297 -0
- data/third_party/abseil-cpp/absl/container/internal/hashtablez_sampler_force_weak_definition.cc +30 -0
- data/third_party/abseil-cpp/absl/container/internal/have_sse.h +49 -0
- data/third_party/abseil-cpp/absl/container/internal/layout.h +741 -0
- data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.cc +48 -0
- data/third_party/abseil-cpp/absl/container/internal/raw_hash_set.h +1882 -0
- data/third_party/abseil-cpp/absl/debugging/internal/address_is_readable.cc +138 -0
- data/third_party/abseil-cpp/absl/debugging/internal/address_is_readable.h +32 -0
- data/third_party/abseil-cpp/absl/debugging/internal/demangle.cc +1895 -0
- data/third_party/abseil-cpp/absl/debugging/internal/demangle.h +71 -0
- data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.cc +382 -0
- data/third_party/abseil-cpp/absl/debugging/internal/elf_mem_image.h +134 -0
- data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_aarch64-inl.inc +192 -0
- data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_arm-inl.inc +125 -0
- data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_config.h +70 -0
- data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_generic-inl.inc +99 -0
- data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_powerpc-inl.inc +248 -0
- data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_unimplemented-inl.inc +24 -0
- data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_win32-inl.inc +85 -0
- data/third_party/abseil-cpp/absl/debugging/internal/stacktrace_x86-inl.inc +346 -0
- data/third_party/abseil-cpp/absl/debugging/internal/symbolize.h +128 -0
- data/third_party/abseil-cpp/absl/debugging/internal/vdso_support.cc +194 -0
- data/third_party/abseil-cpp/absl/debugging/internal/vdso_support.h +158 -0
- data/third_party/abseil-cpp/absl/debugging/stacktrace.cc +140 -0
- data/third_party/abseil-cpp/absl/debugging/stacktrace.h +231 -0
- data/third_party/abseil-cpp/absl/debugging/symbolize.cc +25 -0
- data/third_party/abseil-cpp/absl/debugging/symbolize.h +99 -0
- data/third_party/abseil-cpp/absl/debugging/symbolize_elf.inc +1480 -0
- data/third_party/abseil-cpp/absl/debugging/symbolize_unimplemented.inc +40 -0
- data/third_party/abseil-cpp/absl/debugging/symbolize_win32.inc +81 -0
- data/third_party/abseil-cpp/absl/functional/function_ref.h +139 -0
- data/third_party/abseil-cpp/absl/functional/internal/function_ref.h +106 -0
- data/third_party/abseil-cpp/absl/hash/hash.h +324 -0
- data/third_party/abseil-cpp/absl/hash/internal/city.cc +346 -0
- data/third_party/abseil-cpp/absl/hash/internal/city.h +96 -0
- data/third_party/abseil-cpp/absl/hash/internal/hash.cc +55 -0
- data/third_party/abseil-cpp/absl/hash/internal/hash.h +988 -0
- data/third_party/abseil-cpp/absl/status/status.cc +447 -0
- data/third_party/abseil-cpp/absl/status/status.h +428 -0
- data/third_party/abseil-cpp/absl/status/status_payload_printer.cc +43 -0
- data/third_party/abseil-cpp/absl/status/status_payload_printer.h +51 -0
- data/third_party/abseil-cpp/absl/strings/cord.cc +2019 -0
- data/third_party/abseil-cpp/absl/strings/cord.h +1121 -0
- data/third_party/abseil-cpp/absl/strings/internal/cord_internal.h +151 -0
- data/third_party/abseil-cpp/absl/synchronization/barrier.cc +52 -0
- data/third_party/abseil-cpp/absl/synchronization/barrier.h +79 -0
- data/third_party/abseil-cpp/absl/synchronization/blocking_counter.cc +57 -0
- data/third_party/abseil-cpp/absl/synchronization/blocking_counter.h +99 -0
- data/third_party/abseil-cpp/absl/synchronization/internal/create_thread_identity.cc +140 -0
- data/third_party/abseil-cpp/absl/synchronization/internal/create_thread_identity.h +60 -0
- data/third_party/abseil-cpp/absl/synchronization/internal/graphcycles.cc +697 -0
- data/third_party/abseil-cpp/absl/synchronization/internal/graphcycles.h +141 -0
- data/third_party/abseil-cpp/absl/synchronization/internal/kernel_timeout.h +155 -0
- data/third_party/abseil-cpp/absl/synchronization/internal/mutex_nonprod.inc +261 -0
- data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.cc +106 -0
- data/third_party/abseil-cpp/absl/synchronization/internal/per_thread_sem.h +115 -0
- data/third_party/abseil-cpp/absl/synchronization/internal/waiter.cc +484 -0
- data/third_party/abseil-cpp/absl/synchronization/internal/waiter.h +159 -0
- data/third_party/abseil-cpp/absl/synchronization/mutex.cc +2728 -0
- data/third_party/abseil-cpp/absl/synchronization/mutex.h +1056 -0
- data/third_party/abseil-cpp/absl/synchronization/notification.cc +78 -0
- data/third_party/abseil-cpp/absl/synchronization/notification.h +123 -0
- data/third_party/abseil-cpp/absl/types/bad_variant_access.cc +64 -0
- data/third_party/abseil-cpp/absl/types/bad_variant_access.h +82 -0
- data/third_party/abseil-cpp/absl/types/internal/variant.h +1646 -0
- data/third_party/abseil-cpp/absl/types/variant.h +861 -0
- data/third_party/boringssl-with-bazel/err_data.c +266 -254
- data/third_party/boringssl-with-bazel/src/crypto/asn1/a_bitstr.c +3 -3
- data/third_party/boringssl-with-bazel/src/crypto/asn1/a_enum.c +3 -3
- data/third_party/boringssl-with-bazel/src/crypto/asn1/a_int.c +1 -1
- data/third_party/boringssl-with-bazel/src/crypto/asn1/a_object.c +3 -3
- data/third_party/boringssl-with-bazel/src/crypto/asn1/a_time.c +2 -2
- data/third_party/boringssl-with-bazel/src/crypto/asn1/a_type.c +1 -1
- data/third_party/boringssl-with-bazel/src/crypto/asn1/asn1_lib.c +1 -1
- data/third_party/boringssl-with-bazel/src/crypto/asn1/asn_pack.c +1 -1
- data/third_party/boringssl-with-bazel/src/crypto/asn1/f_enum.c +1 -1
- data/third_party/boringssl-with-bazel/src/crypto/asn1/f_int.c +1 -1
- data/third_party/boringssl-with-bazel/src/crypto/asn1/f_string.c +1 -1
- data/third_party/boringssl-with-bazel/src/crypto/cipher_extra/tls_cbc.c +1 -0
- data/third_party/boringssl-with-bazel/src/crypto/ec_extra/hash_to_curve.c +12 -52
- data/third_party/boringssl-with-bazel/src/crypto/ec_extra/internal.h +0 -22
- data/third_party/boringssl-with-bazel/src/crypto/evp/evp_asn1.c +159 -0
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/aes/mode_wrappers.c +17 -1
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/bn/internal.h +11 -1
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/internal.h +2 -1
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p224-64.c +13 -11
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256-x86_64.c +24 -23
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/p256.c +20 -16
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/simple_mul.c +2 -2
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/ec/util.c +3 -3
- data/third_party/boringssl-with-bazel/src/crypto/fipsmodule/self_check/self_check.c +62 -0
- data/third_party/boringssl-with-bazel/src/crypto/hpke/hpke.c +456 -0
- data/third_party/boringssl-with-bazel/src/crypto/hpke/internal.h +192 -0
- data/third_party/boringssl-with-bazel/src/crypto/mem.c +29 -15
- data/third_party/boringssl-with-bazel/src/crypto/pkcs8/internal.h +7 -0
- data/third_party/boringssl-with-bazel/src/crypto/pkcs8/pkcs8_x509.c +36 -5
- data/third_party/boringssl-with-bazel/src/crypto/trust_token/internal.h +0 -29
- data/third_party/boringssl-with-bazel/src/crypto/trust_token/pmbtoken.c +116 -363
- data/third_party/boringssl-with-bazel/src/crypto/trust_token/trust_token.c +7 -45
- data/third_party/boringssl-with-bazel/src/crypto/x509/a_strex.c +4 -4
- data/third_party/boringssl-with-bazel/src/crypto/x509/algorithm.c +8 -0
- data/third_party/boringssl-with-bazel/src/crypto/x509/asn1_gen.c +4 -4
- data/third_party/boringssl-with-bazel/src/crypto/x509/x509.c +0 -67
- data/third_party/boringssl-with-bazel/src/crypto/x509/x509_cmp.c +13 -6
- data/third_party/boringssl-with-bazel/src/crypto/x509/x509_req.c +10 -0
- data/third_party/boringssl-with-bazel/src/crypto/x509/x509_set.c +41 -0
- data/third_party/boringssl-with-bazel/src/crypto/x509/x509_trs.c +4 -1
- data/third_party/boringssl-with-bazel/src/crypto/x509/x509_vfy.c +28 -9
- data/third_party/boringssl-with-bazel/src/crypto/x509/x509cset.c +25 -0
- data/third_party/boringssl-with-bazel/src/crypto/x509/x_crl.c +35 -13
- data/third_party/boringssl-with-bazel/src/crypto/x509/x_pubkey.c +0 -154
- data/third_party/boringssl-with-bazel/src/crypto/x509/x_sig.c +20 -0
- data/third_party/boringssl-with-bazel/src/crypto/x509/x_x509.c +28 -6
- data/third_party/boringssl-with-bazel/src/crypto/x509v3/internal.h +5 -0
- data/third_party/boringssl-with-bazel/src/crypto/x509v3/v3_purp.c +74 -35
- data/third_party/boringssl-with-bazel/src/include/openssl/aes.h +16 -4
- data/third_party/boringssl-with-bazel/src/include/openssl/arm_arch.h +52 -0
- data/third_party/boringssl-with-bazel/src/include/openssl/asn1.h +22 -22
- data/third_party/boringssl-with-bazel/src/include/openssl/base.h +2 -2
- data/third_party/boringssl-with-bazel/src/include/openssl/evp.h +69 -0
- data/third_party/boringssl-with-bazel/src/include/openssl/ssl.h +72 -23
- data/third_party/boringssl-with-bazel/src/include/openssl/tls1.h +2 -3
- data/third_party/boringssl-with-bazel/src/include/openssl/trust_token.h +1 -10
- data/third_party/boringssl-with-bazel/src/include/openssl/x509.h +800 -715
- data/third_party/boringssl-with-bazel/src/ssl/handoff.cc +3 -3
- data/third_party/boringssl-with-bazel/src/ssl/handshake.cc +9 -2
- data/third_party/boringssl-with-bazel/src/ssl/handshake_client.cc +2 -2
- data/third_party/boringssl-with-bazel/src/ssl/handshake_server.cc +9 -0
- data/third_party/boringssl-with-bazel/src/ssl/internal.h +21 -14
- data/third_party/boringssl-with-bazel/src/ssl/ssl_asn1.cc +7 -7
- data/third_party/boringssl-with-bazel/src/ssl/ssl_cert.cc +3 -6
- data/third_party/boringssl-with-bazel/src/ssl/ssl_lib.cc +38 -0
- data/third_party/boringssl-with-bazel/src/ssl/ssl_session.cc +4 -24
- data/third_party/boringssl-with-bazel/src/ssl/ssl_versions.cc +5 -5
- data/third_party/boringssl-with-bazel/src/ssl/t1_enc.cc +45 -24
- data/third_party/boringssl-with-bazel/src/ssl/t1_lib.cc +34 -9
- data/third_party/boringssl-with-bazel/src/ssl/tls13_client.cc +31 -21
- data/third_party/boringssl-with-bazel/src/ssl/tls13_server.cc +17 -9
- data/third_party/boringssl-with-bazel/src/ssl/tls_record.cc +5 -3
- data/third_party/re2/re2/bitmap256.h +117 -0
- data/third_party/re2/re2/bitstate.cc +385 -0
- data/third_party/re2/re2/compile.cc +1279 -0
- data/third_party/re2/re2/dfa.cc +2130 -0
- data/third_party/re2/re2/filtered_re2.cc +121 -0
- data/third_party/re2/re2/filtered_re2.h +109 -0
- data/third_party/re2/re2/mimics_pcre.cc +197 -0
- data/third_party/re2/re2/nfa.cc +713 -0
- data/third_party/re2/re2/onepass.cc +623 -0
- data/third_party/re2/re2/parse.cc +2464 -0
- data/third_party/re2/re2/perl_groups.cc +119 -0
- data/third_party/re2/re2/pod_array.h +55 -0
- data/third_party/re2/re2/prefilter.cc +710 -0
- data/third_party/re2/re2/prefilter.h +108 -0
- data/third_party/re2/re2/prefilter_tree.cc +407 -0
- data/third_party/re2/re2/prefilter_tree.h +139 -0
- data/third_party/re2/re2/prog.cc +988 -0
- data/third_party/re2/re2/prog.h +436 -0
- data/third_party/re2/re2/re2.cc +1362 -0
- data/third_party/re2/re2/re2.h +1002 -0
- data/third_party/re2/re2/regexp.cc +980 -0
- data/third_party/re2/re2/regexp.h +659 -0
- data/third_party/re2/re2/set.cc +154 -0
- data/third_party/re2/re2/set.h +80 -0
- data/third_party/re2/re2/simplify.cc +657 -0
- data/third_party/re2/re2/sparse_array.h +392 -0
- data/third_party/re2/re2/sparse_set.h +264 -0
- data/third_party/re2/re2/stringpiece.cc +65 -0
- data/third_party/re2/re2/stringpiece.h +210 -0
- data/third_party/re2/re2/tostring.cc +351 -0
- data/third_party/re2/re2/unicode_casefold.cc +582 -0
- data/third_party/re2/re2/unicode_casefold.h +78 -0
- data/third_party/re2/re2/unicode_groups.cc +6269 -0
- data/third_party/re2/re2/unicode_groups.h +67 -0
- data/third_party/re2/re2/walker-inl.h +246 -0
- data/third_party/re2/util/benchmark.h +156 -0
- data/third_party/re2/util/flags.h +26 -0
- data/third_party/re2/util/logging.h +109 -0
- data/third_party/re2/util/malloc_counter.h +19 -0
- data/third_party/re2/util/mix.h +41 -0
- data/third_party/re2/util/mutex.h +148 -0
- data/third_party/re2/util/pcre.cc +1025 -0
- data/third_party/re2/util/pcre.h +681 -0
- data/third_party/re2/util/rune.cc +260 -0
- data/third_party/re2/util/strutil.cc +149 -0
- data/third_party/re2/util/strutil.h +21 -0
- data/third_party/re2/util/test.h +50 -0
- data/third_party/re2/util/utf.h +44 -0
- data/third_party/re2/util/util.h +42 -0
- data/third_party/upb/upb/decode.c +517 -505
- data/third_party/upb/upb/encode.c +165 -123
- data/third_party/upb/upb/msg.c +130 -64
- data/third_party/upb/upb/msg.h +418 -14
- data/third_party/upb/upb/port_def.inc +35 -6
- data/third_party/upb/upb/port_undef.inc +8 -1
- data/third_party/upb/upb/table.c +53 -86
- data/third_party/upb/upb/table.int.h +11 -52
- data/third_party/upb/upb/upb.c +151 -125
- data/third_party/upb/upb/upb.h +91 -147
- data/third_party/upb/upb/upb.hpp +88 -0
- metadata +308 -148
- data/src/core/ext/filters/client_channel/xds/xds_api.cc +0 -1906
- data/src/core/ext/upb-generated/envoy/api/v2/auth/cert.upb.c +0 -21
- data/src/core/ext/upb-generated/envoy/api/v2/auth/cert.upb.h +0 -35
- data/src/core/ext/upb-generated/envoy/api/v2/auth/common.upb.c +0 -114
- data/src/core/ext/upb-generated/envoy/api/v2/auth/common.upb.h +0 -418
- data/src/core/ext/upb-generated/envoy/api/v2/auth/secret.upb.c +0 -72
- data/src/core/ext/upb-generated/envoy/api/v2/auth/secret.upb.h +0 -197
- data/src/core/ext/upb-generated/envoy/api/v2/auth/tls.upb.c +0 -105
- data/src/core/ext/upb-generated/envoy/api/v2/auth/tls.upb.h +0 -378
- data/src/core/ext/upb-generated/envoy/api/v2/cds.upb.h +0 -53
- data/src/core/ext/upb-generated/envoy/api/v2/cluster.upb.c +0 -403
- data/src/core/ext/upb-generated/envoy/api/v2/cluster.upb.h +0 -1447
- data/src/core/ext/upb-generated/envoy/api/v2/cluster/circuit_breaker.upb.c +0 -74
- data/src/core/ext/upb-generated/envoy/api/v2/cluster/circuit_breaker.upb.h +0 -218
- data/src/core/ext/upb-generated/envoy/api/v2/cluster/filter.upb.h +0 -69
- data/src/core/ext/upb-generated/envoy/api/v2/cluster/outlier_detection.upb.h +0 -305
- data/src/core/ext/upb-generated/envoy/api/v2/core/address.upb.c +0 -112
- data/src/core/ext/upb-generated/envoy/api/v2/core/address.upb.h +0 -328
- data/src/core/ext/upb-generated/envoy/api/v2/core/backoff.upb.h +0 -78
- data/src/core/ext/upb-generated/envoy/api/v2/core/base.upb.c +0 -313
- data/src/core/ext/upb-generated/envoy/api/v2/core/base.upb.h +0 -897
- data/src/core/ext/upb-generated/envoy/api/v2/core/config_source.upb.c +0 -96
- data/src/core/ext/upb-generated/envoy/api/v2/core/config_source.upb.h +0 -322
- data/src/core/ext/upb-generated/envoy/api/v2/core/event_service_config.upb.c +0 -34
- data/src/core/ext/upb-generated/envoy/api/v2/core/event_service_config.upb.h +0 -72
- data/src/core/ext/upb-generated/envoy/api/v2/core/grpc_service.upb.c +0 -197
- data/src/core/ext/upb-generated/envoy/api/v2/core/grpc_service.upb.h +0 -642
- data/src/core/ext/upb-generated/envoy/api/v2/core/health_check.upb.c +0 -172
- data/src/core/ext/upb-generated/envoy/api/v2/core/health_check.upb.h +0 -673
- data/src/core/ext/upb-generated/envoy/api/v2/core/http_uri.upb.h +0 -80
- data/src/core/ext/upb-generated/envoy/api/v2/core/protocol.upb.c +0 -152
- data/src/core/ext/upb-generated/envoy/api/v2/core/protocol.upb.h +0 -518
- data/src/core/ext/upb-generated/envoy/api/v2/core/socket_option.upb.h +0 -89
- data/src/core/ext/upb-generated/envoy/api/v2/discovery.upb.c +0 -129
- data/src/core/ext/upb-generated/envoy/api/v2/discovery.upb.h +0 -392
- data/src/core/ext/upb-generated/envoy/api/v2/eds.upb.h +0 -53
- data/src/core/ext/upb-generated/envoy/api/v2/endpoint.upb.c +0 -92
- data/src/core/ext/upb-generated/envoy/api/v2/endpoint.upb.h +0 -240
- data/src/core/ext/upb-generated/envoy/api/v2/endpoint/endpoint.upb.c +0 -18
- data/src/core/ext/upb-generated/envoy/api/v2/endpoint/endpoint.upb.h +0 -33
- data/src/core/ext/upb-generated/envoy/api/v2/endpoint/endpoint_components.upb.c +0 -91
- data/src/core/ext/upb-generated/envoy/api/v2/endpoint/endpoint_components.upb.h +0 -266
- data/src/core/ext/upb-generated/envoy/api/v2/endpoint/load_report.upb.c +0 -112
- data/src/core/ext/upb-generated/envoy/api/v2/endpoint/load_report.upb.h +0 -324
- data/src/core/ext/upb-generated/envoy/api/v2/lds.upb.h +0 -53
- data/src/core/ext/upb-generated/envoy/api/v2/listener.upb.c +0 -109
- data/src/core/ext/upb-generated/envoy/api/v2/listener.upb.h +0 -399
- data/src/core/ext/upb-generated/envoy/api/v2/listener/listener.upb.c +0 -18
- data/src/core/ext/upb-generated/envoy/api/v2/listener/listener.upb.h +0 -33
- data/src/core/ext/upb-generated/envoy/api/v2/listener/listener_components.upb.c +0 -145
- data/src/core/ext/upb-generated/envoy/api/v2/listener/listener_components.upb.h +0 -527
- data/src/core/ext/upb-generated/envoy/api/v2/listener/udp_listener_config.upb.c +0 -43
- data/src/core/ext/upb-generated/envoy/api/v2/listener/udp_listener_config.upb.h +0 -112
- data/src/core/ext/upb-generated/envoy/api/v2/rds.upb.h +0 -53
- data/src/core/ext/upb-generated/envoy/api/v2/route.upb.c +0 -63
- data/src/core/ext/upb-generated/envoy/api/v2/route.upb.h +0 -199
- data/src/core/ext/upb-generated/envoy/api/v2/route/route.upb.c +0 -18
- data/src/core/ext/upb-generated/envoy/api/v2/route/route.upb.h +0 -33
- data/src/core/ext/upb-generated/envoy/api/v2/route/route_components.upb.c +0 -815
- data/src/core/ext/upb-generated/envoy/api/v2/route/route_components.upb.h +0 -3032
- data/src/core/ext/upb-generated/envoy/api/v2/scoped_route.upb.c +0 -59
- data/src/core/ext/upb-generated/envoy/api/v2/scoped_route.upb.h +0 -134
- data/src/core/ext/upb-generated/envoy/api/v2/srds.upb.h +0 -53
- data/src/core/ext/upb-generated/envoy/config/filter/accesslog/v2/accesslog.upb.c +0 -228
- data/src/core/ext/upb-generated/envoy/config/filter/accesslog/v2/accesslog.upb.h +0 -725
- data/src/core/ext/upb-generated/envoy/config/filter/network/http_connection_manager/v2/http_connection_manager.upb.c +0 -316
- data/src/core/ext/upb-generated/envoy/config/filter/network/http_connection_manager/v2/http_connection_manager.upb.h +0 -1132
- data/src/core/ext/upb-generated/envoy/config/listener/v2/api_listener.upb.h +0 -65
- data/src/core/ext/upb-generated/envoy/config/trace/v2/http_tracer.upb.c +0 -51
- data/src/core/ext/upb-generated/envoy/config/trace/v2/http_tracer.upb.h +0 -125
- data/src/core/ext/upb-generated/envoy/service/discovery/v2/ads.upb.h +0 -50
- data/src/core/ext/upb-generated/envoy/service/load_stats/v2/lrs.upb.c +0 -54
- data/src/core/ext/upb-generated/envoy/service/load_stats/v2/lrs.upb.h +0 -134
- data/src/core/ext/upb-generated/envoy/type/matcher/regex.upb.c +0 -63
- data/src/core/ext/upb-generated/envoy/type/matcher/regex.upb.h +0 -144
- data/src/core/ext/upb-generated/envoy/type/matcher/string.upb.c +0 -53
- data/src/core/ext/upb-generated/envoy/type/matcher/string.upb.h +0 -133
- data/src/core/ext/upb-generated/envoy/type/metadata/v2/metadata.upb.c +0 -88
- data/src/core/ext/upb-generated/envoy/type/metadata/v2/metadata.upb.h +0 -258
- data/src/core/ext/upb-generated/envoy/type/percent.upb.h +0 -87
- data/src/core/ext/upb-generated/envoy/type/range.upb.h +0 -112
- data/src/core/ext/upb-generated/envoy/type/semantic_version.upb.h +0 -62
- data/src/core/ext/upb-generated/envoy/type/tracing/v2/custom_tag.upb.c +0 -89
- data/src/core/ext/upb-generated/envoy/type/tracing/v2/custom_tag.upb.h +0 -249
- data/src/core/lib/security/transport/target_authority_table.cc +0 -75
- data/src/core/lib/security/transport/target_authority_table.h +0 -40
- data/src/core/lib/slice/slice_hash_table.h +0 -199
- data/src/core/lib/slice/slice_weak_hash_table.h +0 -102
- data/third_party/upb/upb/generated_util.h +0 -105
@@ -36,7 +36,7 @@
|
|
36
36
|
static_assert(
|
37
37
|
std::is_trivially_destructible<grpc_core::StaticMetadataSlice>::value,
|
38
38
|
"grpc_core::StaticMetadataSlice must be trivially destructible.");
|
39
|
-
#define GRPC_STATIC_MDSTR_COUNT
|
39
|
+
#define GRPC_STATIC_MDSTR_COUNT 110
|
40
40
|
|
41
41
|
void grpc_init_static_metadata_ctx(void);
|
42
42
|
void grpc_destroy_static_metadata_ctx(void);
|
@@ -132,154 +132,161 @@ inline const grpc_core::StaticMetadataSlice* grpc_static_slice_table() {
|
|
132
132
|
/* "/envoy.service.load_stats.v2.LoadReportingService/StreamLoadStats" */
|
133
133
|
#define GRPC_MDSTR_SLASH_ENVOY_DOT_SERVICE_DOT_LOAD_STATS_DOT_V2_DOT_LOADREPORTINGSERVICE_SLASH_STREAMLOADSTATS \
|
134
134
|
(grpc_static_slice_table()[35])
|
135
|
+
/* "/envoy.service.load_stats.v3.LoadReportingService/StreamLoadStats" */
|
136
|
+
#define GRPC_MDSTR_SLASH_ENVOY_DOT_SERVICE_DOT_LOAD_STATS_DOT_V3_DOT_LOADREPORTINGSERVICE_SLASH_STREAMLOADSTATS \
|
137
|
+
(grpc_static_slice_table()[36])
|
135
138
|
/* "/grpc.health.v1.Health/Watch" */
|
136
139
|
#define GRPC_MDSTR_SLASH_GRPC_DOT_HEALTH_DOT_V1_DOT_HEALTH_SLASH_WATCH \
|
137
|
-
(grpc_static_slice_table()[
|
140
|
+
(grpc_static_slice_table()[37])
|
138
141
|
/* "/envoy.service.discovery.v2.AggregatedDiscoveryService/StreamAggregatedResources"
|
139
142
|
*/
|
140
143
|
#define GRPC_MDSTR_SLASH_ENVOY_DOT_SERVICE_DOT_DISCOVERY_DOT_V2_DOT_AGGREGATEDDISCOVERYSERVICE_SLASH_STREAMAGGREGATEDRESOURCES \
|
141
|
-
(grpc_static_slice_table()[
|
144
|
+
(grpc_static_slice_table()[38])
|
145
|
+
/* "/envoy.service.discovery.v3.AggregatedDiscoveryService/StreamAggregatedResources"
|
146
|
+
*/
|
147
|
+
#define GRPC_MDSTR_SLASH_ENVOY_DOT_SERVICE_DOT_DISCOVERY_DOT_V3_DOT_AGGREGATEDDISCOVERYSERVICE_SLASH_STREAMAGGREGATEDRESOURCES \
|
148
|
+
(grpc_static_slice_table()[39])
|
142
149
|
/* "deflate" */
|
143
|
-
#define GRPC_MDSTR_DEFLATE (grpc_static_slice_table()[
|
150
|
+
#define GRPC_MDSTR_DEFLATE (grpc_static_slice_table()[40])
|
144
151
|
/* "gzip" */
|
145
|
-
#define GRPC_MDSTR_GZIP (grpc_static_slice_table()[
|
152
|
+
#define GRPC_MDSTR_GZIP (grpc_static_slice_table()[41])
|
146
153
|
/* "stream/gzip" */
|
147
|
-
#define GRPC_MDSTR_STREAM_SLASH_GZIP (grpc_static_slice_table()[
|
154
|
+
#define GRPC_MDSTR_STREAM_SLASH_GZIP (grpc_static_slice_table()[42])
|
148
155
|
/* "GET" */
|
149
|
-
#define GRPC_MDSTR_GET (grpc_static_slice_table()[
|
156
|
+
#define GRPC_MDSTR_GET (grpc_static_slice_table()[43])
|
150
157
|
/* "POST" */
|
151
|
-
#define GRPC_MDSTR_POST (grpc_static_slice_table()[
|
158
|
+
#define GRPC_MDSTR_POST (grpc_static_slice_table()[44])
|
152
159
|
/* "/" */
|
153
|
-
#define GRPC_MDSTR_SLASH (grpc_static_slice_table()[
|
160
|
+
#define GRPC_MDSTR_SLASH (grpc_static_slice_table()[45])
|
154
161
|
/* "/index.html" */
|
155
|
-
#define GRPC_MDSTR_SLASH_INDEX_DOT_HTML (grpc_static_slice_table()[
|
162
|
+
#define GRPC_MDSTR_SLASH_INDEX_DOT_HTML (grpc_static_slice_table()[46])
|
156
163
|
/* "http" */
|
157
|
-
#define GRPC_MDSTR_HTTP (grpc_static_slice_table()[
|
164
|
+
#define GRPC_MDSTR_HTTP (grpc_static_slice_table()[47])
|
158
165
|
/* "https" */
|
159
|
-
#define GRPC_MDSTR_HTTPS (grpc_static_slice_table()[
|
166
|
+
#define GRPC_MDSTR_HTTPS (grpc_static_slice_table()[48])
|
160
167
|
/* "200" */
|
161
|
-
#define GRPC_MDSTR_200 (grpc_static_slice_table()[
|
168
|
+
#define GRPC_MDSTR_200 (grpc_static_slice_table()[49])
|
162
169
|
/* "204" */
|
163
|
-
#define GRPC_MDSTR_204 (grpc_static_slice_table()[
|
170
|
+
#define GRPC_MDSTR_204 (grpc_static_slice_table()[50])
|
164
171
|
/* "206" */
|
165
|
-
#define GRPC_MDSTR_206 (grpc_static_slice_table()[
|
172
|
+
#define GRPC_MDSTR_206 (grpc_static_slice_table()[51])
|
166
173
|
/* "304" */
|
167
|
-
#define GRPC_MDSTR_304 (grpc_static_slice_table()[
|
174
|
+
#define GRPC_MDSTR_304 (grpc_static_slice_table()[52])
|
168
175
|
/* "400" */
|
169
|
-
#define GRPC_MDSTR_400 (grpc_static_slice_table()[
|
176
|
+
#define GRPC_MDSTR_400 (grpc_static_slice_table()[53])
|
170
177
|
/* "404" */
|
171
|
-
#define GRPC_MDSTR_404 (grpc_static_slice_table()[
|
178
|
+
#define GRPC_MDSTR_404 (grpc_static_slice_table()[54])
|
172
179
|
/* "500" */
|
173
|
-
#define GRPC_MDSTR_500 (grpc_static_slice_table()[
|
180
|
+
#define GRPC_MDSTR_500 (grpc_static_slice_table()[55])
|
174
181
|
/* "accept-charset" */
|
175
|
-
#define GRPC_MDSTR_ACCEPT_CHARSET (grpc_static_slice_table()[
|
182
|
+
#define GRPC_MDSTR_ACCEPT_CHARSET (grpc_static_slice_table()[56])
|
176
183
|
/* "gzip, deflate" */
|
177
|
-
#define GRPC_MDSTR_GZIP_COMMA_DEFLATE (grpc_static_slice_table()[
|
184
|
+
#define GRPC_MDSTR_GZIP_COMMA_DEFLATE (grpc_static_slice_table()[57])
|
178
185
|
/* "accept-language" */
|
179
|
-
#define GRPC_MDSTR_ACCEPT_LANGUAGE (grpc_static_slice_table()[
|
186
|
+
#define GRPC_MDSTR_ACCEPT_LANGUAGE (grpc_static_slice_table()[58])
|
180
187
|
/* "accept-ranges" */
|
181
|
-
#define GRPC_MDSTR_ACCEPT_RANGES (grpc_static_slice_table()[
|
188
|
+
#define GRPC_MDSTR_ACCEPT_RANGES (grpc_static_slice_table()[59])
|
182
189
|
/* "accept" */
|
183
|
-
#define GRPC_MDSTR_ACCEPT (grpc_static_slice_table()[
|
190
|
+
#define GRPC_MDSTR_ACCEPT (grpc_static_slice_table()[60])
|
184
191
|
/* "access-control-allow-origin" */
|
185
|
-
#define GRPC_MDSTR_ACCESS_CONTROL_ALLOW_ORIGIN (grpc_static_slice_table()[
|
192
|
+
#define GRPC_MDSTR_ACCESS_CONTROL_ALLOW_ORIGIN (grpc_static_slice_table()[61])
|
186
193
|
/* "age" */
|
187
|
-
#define GRPC_MDSTR_AGE (grpc_static_slice_table()[
|
194
|
+
#define GRPC_MDSTR_AGE (grpc_static_slice_table()[62])
|
188
195
|
/* "allow" */
|
189
|
-
#define GRPC_MDSTR_ALLOW (grpc_static_slice_table()[
|
196
|
+
#define GRPC_MDSTR_ALLOW (grpc_static_slice_table()[63])
|
190
197
|
/* "authorization" */
|
191
|
-
#define GRPC_MDSTR_AUTHORIZATION (grpc_static_slice_table()[
|
198
|
+
#define GRPC_MDSTR_AUTHORIZATION (grpc_static_slice_table()[64])
|
192
199
|
/* "cache-control" */
|
193
|
-
#define GRPC_MDSTR_CACHE_CONTROL (grpc_static_slice_table()[
|
200
|
+
#define GRPC_MDSTR_CACHE_CONTROL (grpc_static_slice_table()[65])
|
194
201
|
/* "content-disposition" */
|
195
|
-
#define GRPC_MDSTR_CONTENT_DISPOSITION (grpc_static_slice_table()[
|
202
|
+
#define GRPC_MDSTR_CONTENT_DISPOSITION (grpc_static_slice_table()[66])
|
196
203
|
/* "content-language" */
|
197
|
-
#define GRPC_MDSTR_CONTENT_LANGUAGE (grpc_static_slice_table()[
|
204
|
+
#define GRPC_MDSTR_CONTENT_LANGUAGE (grpc_static_slice_table()[67])
|
198
205
|
/* "content-length" */
|
199
|
-
#define GRPC_MDSTR_CONTENT_LENGTH (grpc_static_slice_table()[
|
206
|
+
#define GRPC_MDSTR_CONTENT_LENGTH (grpc_static_slice_table()[68])
|
200
207
|
/* "content-location" */
|
201
|
-
#define GRPC_MDSTR_CONTENT_LOCATION (grpc_static_slice_table()[
|
208
|
+
#define GRPC_MDSTR_CONTENT_LOCATION (grpc_static_slice_table()[69])
|
202
209
|
/* "content-range" */
|
203
|
-
#define GRPC_MDSTR_CONTENT_RANGE (grpc_static_slice_table()[
|
210
|
+
#define GRPC_MDSTR_CONTENT_RANGE (grpc_static_slice_table()[70])
|
204
211
|
/* "cookie" */
|
205
|
-
#define GRPC_MDSTR_COOKIE (grpc_static_slice_table()[
|
212
|
+
#define GRPC_MDSTR_COOKIE (grpc_static_slice_table()[71])
|
206
213
|
/* "date" */
|
207
|
-
#define GRPC_MDSTR_DATE (grpc_static_slice_table()[
|
214
|
+
#define GRPC_MDSTR_DATE (grpc_static_slice_table()[72])
|
208
215
|
/* "etag" */
|
209
|
-
#define GRPC_MDSTR_ETAG (grpc_static_slice_table()[
|
216
|
+
#define GRPC_MDSTR_ETAG (grpc_static_slice_table()[73])
|
210
217
|
/* "expect" */
|
211
|
-
#define GRPC_MDSTR_EXPECT (grpc_static_slice_table()[
|
218
|
+
#define GRPC_MDSTR_EXPECT (grpc_static_slice_table()[74])
|
212
219
|
/* "expires" */
|
213
|
-
#define GRPC_MDSTR_EXPIRES (grpc_static_slice_table()[
|
220
|
+
#define GRPC_MDSTR_EXPIRES (grpc_static_slice_table()[75])
|
214
221
|
/* "from" */
|
215
|
-
#define GRPC_MDSTR_FROM (grpc_static_slice_table()[
|
222
|
+
#define GRPC_MDSTR_FROM (grpc_static_slice_table()[76])
|
216
223
|
/* "if-match" */
|
217
|
-
#define GRPC_MDSTR_IF_MATCH (grpc_static_slice_table()[
|
224
|
+
#define GRPC_MDSTR_IF_MATCH (grpc_static_slice_table()[77])
|
218
225
|
/* "if-modified-since" */
|
219
|
-
#define GRPC_MDSTR_IF_MODIFIED_SINCE (grpc_static_slice_table()[
|
226
|
+
#define GRPC_MDSTR_IF_MODIFIED_SINCE (grpc_static_slice_table()[78])
|
220
227
|
/* "if-none-match" */
|
221
|
-
#define GRPC_MDSTR_IF_NONE_MATCH (grpc_static_slice_table()[
|
228
|
+
#define GRPC_MDSTR_IF_NONE_MATCH (grpc_static_slice_table()[79])
|
222
229
|
/* "if-range" */
|
223
|
-
#define GRPC_MDSTR_IF_RANGE (grpc_static_slice_table()[
|
230
|
+
#define GRPC_MDSTR_IF_RANGE (grpc_static_slice_table()[80])
|
224
231
|
/* "if-unmodified-since" */
|
225
|
-
#define GRPC_MDSTR_IF_UNMODIFIED_SINCE (grpc_static_slice_table()[
|
232
|
+
#define GRPC_MDSTR_IF_UNMODIFIED_SINCE (grpc_static_slice_table()[81])
|
226
233
|
/* "last-modified" */
|
227
|
-
#define GRPC_MDSTR_LAST_MODIFIED (grpc_static_slice_table()[
|
234
|
+
#define GRPC_MDSTR_LAST_MODIFIED (grpc_static_slice_table()[82])
|
228
235
|
/* "link" */
|
229
|
-
#define GRPC_MDSTR_LINK (grpc_static_slice_table()[
|
236
|
+
#define GRPC_MDSTR_LINK (grpc_static_slice_table()[83])
|
230
237
|
/* "location" */
|
231
|
-
#define GRPC_MDSTR_LOCATION (grpc_static_slice_table()[
|
238
|
+
#define GRPC_MDSTR_LOCATION (grpc_static_slice_table()[84])
|
232
239
|
/* "max-forwards" */
|
233
|
-
#define GRPC_MDSTR_MAX_FORWARDS (grpc_static_slice_table()[
|
240
|
+
#define GRPC_MDSTR_MAX_FORWARDS (grpc_static_slice_table()[85])
|
234
241
|
/* "proxy-authenticate" */
|
235
|
-
#define GRPC_MDSTR_PROXY_AUTHENTICATE (grpc_static_slice_table()[
|
242
|
+
#define GRPC_MDSTR_PROXY_AUTHENTICATE (grpc_static_slice_table()[86])
|
236
243
|
/* "proxy-authorization" */
|
237
|
-
#define GRPC_MDSTR_PROXY_AUTHORIZATION (grpc_static_slice_table()[
|
244
|
+
#define GRPC_MDSTR_PROXY_AUTHORIZATION (grpc_static_slice_table()[87])
|
238
245
|
/* "range" */
|
239
|
-
#define GRPC_MDSTR_RANGE (grpc_static_slice_table()[
|
246
|
+
#define GRPC_MDSTR_RANGE (grpc_static_slice_table()[88])
|
240
247
|
/* "referer" */
|
241
|
-
#define GRPC_MDSTR_REFERER (grpc_static_slice_table()[
|
248
|
+
#define GRPC_MDSTR_REFERER (grpc_static_slice_table()[89])
|
242
249
|
/* "refresh" */
|
243
|
-
#define GRPC_MDSTR_REFRESH (grpc_static_slice_table()[
|
250
|
+
#define GRPC_MDSTR_REFRESH (grpc_static_slice_table()[90])
|
244
251
|
/* "retry-after" */
|
245
|
-
#define GRPC_MDSTR_RETRY_AFTER (grpc_static_slice_table()[
|
252
|
+
#define GRPC_MDSTR_RETRY_AFTER (grpc_static_slice_table()[91])
|
246
253
|
/* "server" */
|
247
|
-
#define GRPC_MDSTR_SERVER (grpc_static_slice_table()[
|
254
|
+
#define GRPC_MDSTR_SERVER (grpc_static_slice_table()[92])
|
248
255
|
/* "set-cookie" */
|
249
|
-
#define GRPC_MDSTR_SET_COOKIE (grpc_static_slice_table()[
|
256
|
+
#define GRPC_MDSTR_SET_COOKIE (grpc_static_slice_table()[93])
|
250
257
|
/* "strict-transport-security" */
|
251
|
-
#define GRPC_MDSTR_STRICT_TRANSPORT_SECURITY (grpc_static_slice_table()[
|
258
|
+
#define GRPC_MDSTR_STRICT_TRANSPORT_SECURITY (grpc_static_slice_table()[94])
|
252
259
|
/* "transfer-encoding" */
|
253
|
-
#define GRPC_MDSTR_TRANSFER_ENCODING (grpc_static_slice_table()[
|
260
|
+
#define GRPC_MDSTR_TRANSFER_ENCODING (grpc_static_slice_table()[95])
|
254
261
|
/* "vary" */
|
255
|
-
#define GRPC_MDSTR_VARY (grpc_static_slice_table()[
|
262
|
+
#define GRPC_MDSTR_VARY (grpc_static_slice_table()[96])
|
256
263
|
/* "via" */
|
257
|
-
#define GRPC_MDSTR_VIA (grpc_static_slice_table()[
|
264
|
+
#define GRPC_MDSTR_VIA (grpc_static_slice_table()[97])
|
258
265
|
/* "www-authenticate" */
|
259
|
-
#define GRPC_MDSTR_WWW_AUTHENTICATE (grpc_static_slice_table()[
|
266
|
+
#define GRPC_MDSTR_WWW_AUTHENTICATE (grpc_static_slice_table()[98])
|
260
267
|
/* "0" */
|
261
|
-
#define GRPC_MDSTR_0 (grpc_static_slice_table()[
|
268
|
+
#define GRPC_MDSTR_0 (grpc_static_slice_table()[99])
|
262
269
|
/* "identity" */
|
263
|
-
#define GRPC_MDSTR_IDENTITY (grpc_static_slice_table()[
|
270
|
+
#define GRPC_MDSTR_IDENTITY (grpc_static_slice_table()[100])
|
264
271
|
/* "trailers" */
|
265
|
-
#define GRPC_MDSTR_TRAILERS (grpc_static_slice_table()[
|
272
|
+
#define GRPC_MDSTR_TRAILERS (grpc_static_slice_table()[101])
|
266
273
|
/* "application/grpc" */
|
267
|
-
#define GRPC_MDSTR_APPLICATION_SLASH_GRPC (grpc_static_slice_table()[
|
274
|
+
#define GRPC_MDSTR_APPLICATION_SLASH_GRPC (grpc_static_slice_table()[102])
|
268
275
|
/* "grpc" */
|
269
|
-
#define GRPC_MDSTR_GRPC (grpc_static_slice_table()[
|
276
|
+
#define GRPC_MDSTR_GRPC (grpc_static_slice_table()[103])
|
270
277
|
/* "PUT" */
|
271
|
-
#define GRPC_MDSTR_PUT (grpc_static_slice_table()[
|
278
|
+
#define GRPC_MDSTR_PUT (grpc_static_slice_table()[104])
|
272
279
|
/* "lb-cost-bin" */
|
273
|
-
#define GRPC_MDSTR_LB_COST_BIN (grpc_static_slice_table()[
|
280
|
+
#define GRPC_MDSTR_LB_COST_BIN (grpc_static_slice_table()[105])
|
274
281
|
/* "identity,deflate" */
|
275
|
-
#define GRPC_MDSTR_IDENTITY_COMMA_DEFLATE (grpc_static_slice_table()[
|
282
|
+
#define GRPC_MDSTR_IDENTITY_COMMA_DEFLATE (grpc_static_slice_table()[106])
|
276
283
|
/* "identity,gzip" */
|
277
|
-
#define GRPC_MDSTR_IDENTITY_COMMA_GZIP (grpc_static_slice_table()[
|
284
|
+
#define GRPC_MDSTR_IDENTITY_COMMA_GZIP (grpc_static_slice_table()[107])
|
278
285
|
/* "deflate,gzip" */
|
279
|
-
#define GRPC_MDSTR_DEFLATE_COMMA_GZIP (grpc_static_slice_table()[
|
286
|
+
#define GRPC_MDSTR_DEFLATE_COMMA_GZIP (grpc_static_slice_table()[108])
|
280
287
|
/* "identity,deflate,gzip" */
|
281
288
|
#define GRPC_MDSTR_IDENTITY_COMMA_DEFLATE_COMMA_GZIP \
|
282
|
-
(grpc_static_slice_table()[
|
289
|
+
(grpc_static_slice_table()[109])
|
283
290
|
|
284
291
|
namespace grpc_core {
|
285
292
|
struct StaticSliceRefcount;
|
@@ -242,6 +242,12 @@ struct grpc_transport_stream_op_batch_payload {
|
|
242
242
|
|
243
243
|
struct {
|
244
244
|
grpc_metadata_batch* send_trailing_metadata = nullptr;
|
245
|
+
// Set by the transport to true if the stream successfully wrote the
|
246
|
+
// trailing metadata. If this is not set but there was a send trailing
|
247
|
+
// metadata op present, this can indicate that a server call can be marked
|
248
|
+
// as a cancellation (since the stream was write-closed before status could
|
249
|
+
// be delivered).
|
250
|
+
bool* sent = nullptr;
|
245
251
|
} send_trailing_metadata;
|
246
252
|
|
247
253
|
struct {
|
@@ -453,4 +459,11 @@ grpc_transport_op* grpc_make_transport_op(grpc_closure* on_consumed);
|
|
453
459
|
grpc_transport_stream_op_batch* grpc_make_transport_stream_op(
|
454
460
|
grpc_closure* on_consumed);
|
455
461
|
|
462
|
+
namespace grpc_core {
|
463
|
+
// This is the key to be used for loading/storing keepalive_throttling in the
|
464
|
+
// absl::Status object.
|
465
|
+
constexpr const char* kKeepaliveThrottlingKey =
|
466
|
+
"grpc.internal.keepalive_throttling";
|
467
|
+
} // namespace grpc_core
|
468
|
+
|
456
469
|
#endif /* GRPC_CORE_LIB_TRANSPORT_TRANSPORT_H */
|
@@ -22,10 +22,13 @@
|
|
22
22
|
|
23
23
|
#include <string.h>
|
24
24
|
|
25
|
+
#include <string>
|
26
|
+
|
27
|
+
#include "absl/strings/str_format.h"
|
28
|
+
|
25
29
|
#include <grpc/slice_buffer.h>
|
26
30
|
#include <grpc/support/alloc.h>
|
27
31
|
#include <grpc/support/log.h>
|
28
|
-
#include <grpc/support/string_util.h>
|
29
32
|
|
30
33
|
#include "src/core/lib/gpr/string.h"
|
31
34
|
#include "src/core/lib/slice/percent_encoding.h"
|
@@ -35,34 +38,25 @@
|
|
35
38
|
/** a size_t default value... maps to all 1's */
|
36
39
|
#define NOT_SET (~(size_t)0)
|
37
40
|
|
38
|
-
static grpc_uri* bad_uri(
|
39
|
-
bool suppress_errors) {
|
40
|
-
char* line_prefix;
|
41
|
-
size_t pfx_len;
|
42
|
-
|
41
|
+
static grpc_uri* bad_uri(absl::string_view uri_text, size_t pos,
|
42
|
+
const char* section, bool suppress_errors) {
|
43
43
|
if (!suppress_errors) {
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
line_prefix = static_cast<char*>(gpr_malloc(pfx_len + 1));
|
50
|
-
memset(line_prefix, ' ', pfx_len);
|
51
|
-
line_prefix[pfx_len] = 0;
|
52
|
-
gpr_log(GPR_ERROR, "%s^ here", line_prefix);
|
53
|
-
gpr_free(line_prefix);
|
44
|
+
std::string line_prefix = absl::StrFormat("bad uri.%s: '", section);
|
45
|
+
gpr_log(GPR_ERROR, "%s%s'", line_prefix.c_str(),
|
46
|
+
std::string(uri_text).c_str());
|
47
|
+
size_t pfx_len = line_prefix.size() + pos;
|
48
|
+
gpr_log(GPR_ERROR, "%s^ here", std::string(pfx_len, ' ').c_str());
|
54
49
|
}
|
55
|
-
|
56
50
|
return nullptr;
|
57
51
|
}
|
58
52
|
|
59
53
|
/** Returns a copy of percent decoded \a src[begin, end) */
|
60
|
-
static char* decode_and_copy_component(
|
54
|
+
static char* decode_and_copy_component(absl::string_view src, size_t begin,
|
61
55
|
size_t end) {
|
62
56
|
grpc_slice component =
|
63
57
|
(begin == NOT_SET || end == NOT_SET)
|
64
58
|
? grpc_empty_slice()
|
65
|
-
: grpc_slice_from_copied_buffer(src + begin, end - begin);
|
59
|
+
: grpc_slice_from_copied_buffer(src.data() + begin, end - begin);
|
66
60
|
grpc_slice decoded_component =
|
67
61
|
grpc_permissive_percent_decode_slice(component);
|
68
62
|
char* out = grpc_dump_slice(decoded_component, GPR_DUMP_ASCII);
|
@@ -79,7 +73,7 @@ static bool valid_hex(char c) {
|
|
79
73
|
/** Returns how many chars to advance if \a uri_text[i] begins a valid \a pchar
|
80
74
|
* production. If \a uri_text[i] introduces an invalid \a pchar (such as percent
|
81
75
|
* sign not followed by two hex digits), NOT_SET is returned. */
|
82
|
-
static size_t parse_pchar(
|
76
|
+
static size_t parse_pchar(absl::string_view uri_text, size_t i) {
|
83
77
|
/* pchar = unreserved / pct-encoded / sub-delims / ":" / "@"
|
84
78
|
* unreserved = ALPHA / DIGIT / "-" / "." / "_" / "~"
|
85
79
|
* pct-encoded = "%" HEXDIG HEXDIG
|
@@ -112,7 +106,8 @@ static size_t parse_pchar(const char* uri_text, size_t i) {
|
|
112
106
|
case '=':
|
113
107
|
return 1;
|
114
108
|
case '%': /* pct-encoded */
|
115
|
-
if (
|
109
|
+
if (uri_text.size() > i + 2 && valid_hex(uri_text[i + 1]) &&
|
110
|
+
valid_hex(uri_text[i + 2])) {
|
116
111
|
return 2;
|
117
112
|
}
|
118
113
|
return NOT_SET;
|
@@ -121,9 +116,8 @@ static size_t parse_pchar(const char* uri_text, size_t i) {
|
|
121
116
|
}
|
122
117
|
|
123
118
|
/* *( pchar / "?" / "/" ) */
|
124
|
-
static int parse_fragment_or_query(
|
125
|
-
|
126
|
-
while ((c = uri_text[*i]) != 0) {
|
119
|
+
static int parse_fragment_or_query(absl::string_view uri_text, size_t* i) {
|
120
|
+
while (uri_text.size() > *i) {
|
127
121
|
const size_t advance = parse_pchar(uri_text, *i); /* pchar */
|
128
122
|
switch (advance) {
|
129
123
|
case 0: /* uri_text[i] isn't in pchar */
|
@@ -185,7 +179,7 @@ static void parse_query_parts(grpc_uri* uri) {
|
|
185
179
|
}
|
186
180
|
}
|
187
181
|
|
188
|
-
grpc_uri* grpc_uri_parse(
|
182
|
+
grpc_uri* grpc_uri_parse(absl::string_view uri_text, bool suppress_errors) {
|
189
183
|
grpc_uri* uri;
|
190
184
|
size_t scheme_begin = 0;
|
191
185
|
size_t scheme_end = NOT_SET;
|
@@ -199,7 +193,7 @@ grpc_uri* grpc_uri_parse(const char* uri_text, bool suppress_errors) {
|
|
199
193
|
size_t fragment_end = NOT_SET;
|
200
194
|
size_t i;
|
201
195
|
|
202
|
-
for (i = scheme_begin;
|
196
|
+
for (i = scheme_begin; i < uri_text.size(); ++i) {
|
203
197
|
if (uri_text[i] == ':') {
|
204
198
|
scheme_end = i;
|
205
199
|
break;
|
@@ -218,15 +212,16 @@ grpc_uri* grpc_uri_parse(const char* uri_text, bool suppress_errors) {
|
|
218
212
|
return bad_uri(uri_text, i, "scheme", suppress_errors);
|
219
213
|
}
|
220
214
|
|
221
|
-
if (uri_text
|
215
|
+
if (uri_text.size() > scheme_end + 2 && uri_text[scheme_end + 1] == '/' &&
|
216
|
+
uri_text[scheme_end + 2] == '/') {
|
222
217
|
authority_begin = scheme_end + 3;
|
223
|
-
for (i = authority_begin; uri_text
|
218
|
+
for (i = authority_begin; uri_text.size() > i && authority_end == NOT_SET;
|
224
219
|
i++) {
|
225
220
|
if (uri_text[i] == '/' || uri_text[i] == '?' || uri_text[i] == '#') {
|
226
221
|
authority_end = i;
|
227
222
|
}
|
228
223
|
}
|
229
|
-
if (authority_end == NOT_SET && uri_text
|
224
|
+
if (authority_end == NOT_SET && uri_text.size() == i) {
|
230
225
|
authority_end = i;
|
231
226
|
}
|
232
227
|
if (authority_end == NOT_SET) {
|
@@ -238,34 +233,34 @@ grpc_uri* grpc_uri_parse(const char* uri_text, bool suppress_errors) {
|
|
238
233
|
path_begin = scheme_end + 1;
|
239
234
|
}
|
240
235
|
|
241
|
-
for (i = path_begin;
|
236
|
+
for (i = path_begin; i < uri_text.size(); ++i) {
|
242
237
|
if (uri_text[i] == '?' || uri_text[i] == '#') {
|
243
238
|
path_end = i;
|
244
239
|
break;
|
245
240
|
}
|
246
241
|
}
|
247
|
-
if (path_end == NOT_SET && uri_text
|
242
|
+
if (path_end == NOT_SET && uri_text.size() == i) {
|
248
243
|
path_end = i;
|
249
244
|
}
|
250
245
|
if (path_end == NOT_SET) {
|
251
246
|
return bad_uri(uri_text, i, "path", suppress_errors);
|
252
247
|
}
|
253
248
|
|
254
|
-
if (uri_text[i] == '?') {
|
249
|
+
if (uri_text.size() > i && uri_text[i] == '?') {
|
255
250
|
query_begin = ++i;
|
256
251
|
if (!parse_fragment_or_query(uri_text, &i)) {
|
257
252
|
return bad_uri(uri_text, i, "query", suppress_errors);
|
258
|
-
} else if (uri_text
|
253
|
+
} else if (uri_text.size() > i && uri_text[i] != '#') {
|
259
254
|
/* We must be at the end or at the beginning of a fragment */
|
260
255
|
return bad_uri(uri_text, i, "query", suppress_errors);
|
261
256
|
}
|
262
257
|
query_end = i;
|
263
258
|
}
|
264
|
-
if (uri_text[i] == '#') {
|
259
|
+
if (uri_text.size() > i && uri_text[i] == '#') {
|
265
260
|
fragment_begin = ++i;
|
266
261
|
if (!parse_fragment_or_query(uri_text, &i)) {
|
267
262
|
return bad_uri(uri_text, i - fragment_end, "fragment", suppress_errors);
|
268
|
-
} else if (uri_text
|
263
|
+
} else if (uri_text.size() > i) {
|
269
264
|
/* We must be at the end */
|
270
265
|
return bad_uri(uri_text, i, "fragment", suppress_errors);
|
271
266
|
}
|
@@ -21,6 +21,8 @@
|
|
21
21
|
|
22
22
|
#include <grpc/support/port_platform.h>
|
23
23
|
|
24
|
+
#include "absl/strings/string_view.h"
|
25
|
+
|
24
26
|
#include <stddef.h>
|
25
27
|
|
26
28
|
struct grpc_uri {
|
@@ -37,7 +39,7 @@ struct grpc_uri {
|
|
37
39
|
char* fragment;
|
38
40
|
};
|
39
41
|
/** parse a uri, return NULL on failure */
|
40
|
-
grpc_uri* grpc_uri_parse(
|
42
|
+
grpc_uri* grpc_uri_parse(absl::string_view uri_text, bool suppress_errors);
|
41
43
|
|
42
44
|
/** return the part of a query string after the '=' in "?key=xxx&...", or NULL
|
43
45
|
* if key is not present */
|
@@ -64,6 +64,8 @@ void grpc_max_age_filter_init(void);
|
|
64
64
|
void grpc_max_age_filter_shutdown(void);
|
65
65
|
void grpc_message_size_filter_init(void);
|
66
66
|
void grpc_message_size_filter_shutdown(void);
|
67
|
+
void grpc_service_config_channel_arg_filter_init(void);
|
68
|
+
void grpc_service_config_channel_arg_filter_shutdown(void);
|
67
69
|
void grpc_client_authority_filter_init(void);
|
68
70
|
void grpc_client_authority_filter_shutdown(void);
|
69
71
|
void grpc_workaround_cronet_compression_filter_init(void);
|
@@ -114,6 +116,8 @@ void grpc_register_built_in_plugins(void) {
|
|
114
116
|
grpc_max_age_filter_shutdown);
|
115
117
|
grpc_register_plugin(grpc_message_size_filter_init,
|
116
118
|
grpc_message_size_filter_shutdown);
|
119
|
+
grpc_register_plugin(grpc_service_config_channel_arg_filter_init,
|
120
|
+
grpc_service_config_channel_arg_filter_shutdown);
|
117
121
|
grpc_register_plugin(grpc_client_authority_filter_init,
|
118
122
|
grpc_client_authority_filter_shutdown);
|
119
123
|
grpc_register_plugin(grpc_workaround_cronet_compression_filter_init,
|