grpc 1.0.1 → 1.1.2
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 +3696 -867
- data/etc/roots.pem +39 -111
- data/include/grpc/byte_buffer.h +64 -1
- data/include/grpc/census.h +40 -96
- data/include/grpc/compression.h +2 -1
- data/include/grpc/grpc.h +42 -7
- data/include/grpc/grpc_posix.h +8 -5
- data/include/grpc/impl/codegen/atm.h +3 -0
- data/include/grpc/impl/codegen/atm_gcc_atomic.h +2 -0
- data/include/grpc/impl/codegen/atm_gcc_sync.h +8 -0
- data/include/grpc/impl/codegen/atm_windows.h +4 -0
- data/include/grpc/impl/codegen/byte_buffer_reader.h +4 -4
- data/include/grpc/impl/codegen/compression_types.h +1 -1
- data/include/grpc/impl/codegen/connectivity_state.h +2 -0
- data/include/grpc/impl/codegen/exec_ctx_fwd.h +41 -0
- data/include/grpc/impl/codegen/gpr_slice.h +84 -0
- data/include/grpc/impl/codegen/{alloc.h → gpr_types.h} +30 -29
- data/include/grpc/impl/codegen/grpc_types.h +91 -9
- data/include/grpc/impl/codegen/port_platform.h +25 -92
- data/include/grpc/impl/codegen/slice.h +54 -97
- data/include/grpc/impl/codegen/sync.h +0 -253
- data/include/grpc/module.modulemap +0 -2
- data/include/grpc/slice.h +132 -0
- data/include/grpc/{impl/codegen/slice_buffer.h → slice_buffer.h} +22 -39
- data/include/grpc/support/alloc.h +40 -1
- data/include/grpc/support/log.h +80 -1
- data/include/grpc/support/log_windows.h +2 -0
- data/include/grpc/support/string_util.h +1 -1
- data/include/grpc/support/sync.h +252 -0
- data/include/grpc/support/time.h +67 -1
- data/src/boringssl/err_data.c +639 -627
- data/src/core/ext/census/base_resources.c +71 -0
- data/src/core/ext/census/base_resources.h +39 -0
- data/src/core/ext/census/gen/census.pb.c +26 -29
- data/src/core/ext/census/gen/census.pb.h +68 -67
- data/src/core/ext/census/gen/trace_context.pb.c +81 -0
- data/src/core/ext/census/gen/trace_context.pb.h +99 -0
- data/src/core/ext/census/grpc_filter.c +22 -16
- data/src/core/ext/census/grpc_plugin.c +2 -1
- data/src/core/ext/census/initialize.c +16 -4
- data/src/core/ext/census/mlog.h +1 -1
- data/src/core/ext/census/placeholders.c +0 -45
- data/src/core/ext/census/resource.c +312 -0
- data/src/core/ext/census/resource.h +63 -0
- data/src/core/ext/census/trace_context.c +86 -0
- data/src/core/ext/census/trace_context.h +68 -0
- data/src/core/ext/census/tracing.c +8 -2
- data/src/core/ext/{client_config → client_channel}/channel_connectivity.c +8 -4
- data/src/core/ext/client_channel/client_channel.c +1218 -0
- data/src/core/ext/{client_config → client_channel}/client_channel.h +8 -11
- data/src/core/ext/{client_config → client_channel}/client_channel_factory.c +33 -3
- data/src/core/ext/{client_config → client_channel}/client_channel_factory.h +15 -8
- data/src/core/ext/{client_config/client_config_plugin.c → client_channel/client_channel_plugin.c} +16 -15
- data/src/core/ext/{client_config → client_channel}/connector.c +1 -1
- data/src/core/ext/{client_config → client_channel}/connector.h +5 -8
- data/{include/grpc/support/slice_buffer.h → src/core/ext/client_channel/default_initial_connect_string.c} +4 -5
- data/src/core/ext/client_channel/http_connect_handshaker.c +399 -0
- data/src/core/ext/client_channel/http_connect_handshaker.h +52 -0
- data/src/core/ext/{client_config → client_channel}/initial_connect_string.c +6 -7
- data/src/core/ext/{client_config → client_channel}/initial_connect_string.h +10 -10
- data/src/core/ext/{client_config → client_channel}/lb_policy.c +11 -11
- data/src/core/ext/{client_config → client_channel}/lb_policy.h +68 -27
- data/src/core/ext/client_channel/lb_policy_factory.c +163 -0
- data/src/core/ext/{client_config → client_channel}/lb_policy_factory.h +64 -9
- data/src/core/ext/{client_config → client_channel}/lb_policy_registry.c +6 -4
- data/src/core/ext/{client_config → client_channel}/lb_policy_registry.h +4 -4
- data/src/core/ext/{client_config → client_channel}/parse_address.c +21 -14
- data/src/core/ext/{client_config → client_channel}/parse_address.h +8 -10
- data/src/core/ext/{client_config → client_channel}/resolver.c +3 -4
- data/src/core/ext/{client_config → client_channel}/resolver.h +11 -15
- data/src/core/ext/{client_config → client_channel}/resolver_factory.c +4 -3
- data/src/core/ext/{client_config → client_channel}/resolver_factory.h +13 -11
- data/src/core/ext/{client_config → client_channel}/resolver_registry.c +54 -34
- data/src/core/ext/{client_config → client_channel}/resolver_registry.h +21 -8
- data/src/core/ext/{client_config → client_channel}/subchannel.c +208 -119
- data/src/core/ext/{client_config → client_channel}/subchannel.h +21 -11
- data/src/core/ext/{client_config → client_channel}/subchannel_index.c +6 -17
- data/src/core/ext/{client_config → client_channel}/subchannel_index.h +7 -7
- data/src/core/ext/{client_config → client_channel}/uri_parser.c +21 -28
- data/src/core/ext/{client_config → client_channel}/uri_parser.h +3 -3
- data/src/core/ext/lb_policy/grpclb/grpclb.c +1406 -0
- data/src/core/ext/lb_policy/grpclb/grpclb.h +44 -0
- data/src/core/ext/lb_policy/grpclb/load_balancer_api.c +117 -37
- data/src/core/ext/lb_policy/grpclb/load_balancer_api.h +31 -12
- data/src/core/ext/lb_policy/grpclb/proto/grpc/lb/v1/load_balancer.pb.c +6 -36
- data/src/core/ext/lb_policy/grpclb/proto/grpc/lb/v1/load_balancer.pb.h +22 -42
- data/src/core/ext/lb_policy/pick_first/pick_first.c +64 -46
- data/src/core/ext/lb_policy/round_robin/round_robin.c +324 -160
- data/src/core/ext/load_reporting/load_reporting.c +7 -56
- data/src/core/ext/load_reporting/load_reporting.h +41 -28
- data/src/core/ext/load_reporting/load_reporting_filter.c +132 -42
- data/src/core/ext/load_reporting/load_reporting_filter.h +1 -0
- data/src/core/ext/resolver/dns/native/dns_resolver.c +88 -80
- data/src/core/ext/resolver/sockaddr/sockaddr_resolver.c +57 -102
- data/src/core/ext/transport/chttp2/alpn/alpn.c +1 -1
- data/src/core/ext/transport/chttp2/client/chttp2_connector.c +253 -0
- data/src/core/{lib/iomgr/ev_poll_and_epoll_posix.h → ext/transport/chttp2/client/chttp2_connector.h} +5 -5
- data/src/core/ext/transport/chttp2/client/insecure/channel_create.c +31 -160
- data/src/core/ext/transport/chttp2/client/insecure/channel_create_posix.c +5 -5
- data/src/core/ext/transport/chttp2/client/secure/secure_channel_create.c +44 -243
- data/src/core/ext/transport/chttp2/server/chttp2_server.c +342 -0
- data/src/core/ext/transport/chttp2/server/chttp2_server.h +47 -0
- data/src/core/ext/transport/chttp2/server/insecure/server_chttp2.c +11 -124
- data/src/core/ext/transport/chttp2/server/insecure/server_chttp2_posix.c +20 -9
- data/src/core/ext/transport/chttp2/server/secure/server_secure_chttp2.c +28 -236
- data/src/core/ext/transport/chttp2/transport/bin_decoder.c +31 -27
- data/src/core/ext/transport/chttp2/transport/bin_decoder.h +5 -4
- data/src/core/ext/transport/chttp2/transport/bin_encoder.c +25 -22
- data/src/core/ext/transport/chttp2/transport/bin_encoder.h +8 -7
- data/src/core/ext/transport/chttp2/transport/chttp2_plugin.c +0 -3
- data/src/core/ext/transport/chttp2/transport/chttp2_transport.c +1345 -1521
- data/src/core/ext/transport/chttp2/transport/chttp2_transport.h +3 -1
- data/src/core/ext/transport/chttp2/transport/frame.h +3 -5
- data/src/core/ext/transport/chttp2/transport/frame_data.c +50 -47
- data/src/core/ext/transport/chttp2/transport/frame_data.h +8 -9
- data/src/core/ext/transport/chttp2/transport/frame_goaway.c +19 -21
- data/src/core/ext/transport/chttp2/transport/frame_goaway.h +9 -8
- data/src/core/ext/transport/chttp2/transport/frame_ping.c +13 -12
- data/src/core/ext/transport/chttp2/transport/frame_ping.h +6 -6
- data/src/core/ext/transport/chttp2/transport/frame_rst_stream.c +31 -19
- data/src/core/ext/transport/chttp2/transport/frame_rst_stream.h +8 -7
- data/src/core/ext/transport/chttp2/transport/frame_settings.c +22 -25
- data/src/core/ext/transport/chttp2/transport/frame_settings.h +9 -8
- data/src/core/ext/transport/chttp2/transport/frame_window_update.c +26 -18
- data/src/core/ext/transport/chttp2/transport/frame_window_update.h +5 -6
- data/src/core/ext/transport/chttp2/transport/hpack_encoder.c +68 -58
- data/src/core/ext/transport/chttp2/transport/hpack_encoder.h +8 -5
- data/src/core/ext/transport/chttp2/transport/hpack_parser.c +327 -214
- data/src/core/ext/transport/chttp2/transport/hpack_parser.h +14 -9
- data/src/core/ext/transport/chttp2/transport/hpack_table.c +24 -19
- data/src/core/ext/transport/chttp2/transport/hpack_table.h +9 -6
- data/src/core/ext/transport/chttp2/transport/incoming_metadata.c +2 -2
- data/src/core/ext/transport/chttp2/transport/incoming_metadata.h +1 -1
- data/src/core/ext/transport/chttp2/transport/internal.h +284 -436
- data/src/core/ext/transport/chttp2/transport/parsing.c +355 -590
- data/src/core/ext/transport/chttp2/transport/stream_lists.c +36 -309
- data/src/core/ext/transport/chttp2/transport/stream_map.c +13 -34
- data/src/core/ext/transport/chttp2/transport/stream_map.h +3 -4
- data/src/core/ext/transport/chttp2/transport/writing.c +174 -286
- data/src/core/lib/channel/channel_args.c +70 -13
- data/src/core/lib/channel/channel_args.h +28 -2
- data/src/core/lib/channel/channel_stack.c +77 -28
- data/src/core/lib/channel/channel_stack.h +61 -23
- data/src/core/lib/channel/channel_stack_builder.c +33 -25
- data/src/core/lib/channel/channel_stack_builder.h +17 -8
- data/src/core/lib/channel/compress_filter.c +52 -36
- data/src/core/lib/channel/connected_channel.c +20 -12
- data/src/core/lib/channel/connected_channel.h +2 -1
- data/src/core/lib/channel/context.h +13 -1
- data/src/core/lib/channel/deadline_filter.c +344 -0
- data/src/core/lib/channel/deadline_filter.h +99 -0
- data/src/core/lib/channel/handshaker.c +240 -0
- data/src/core/lib/channel/handshaker.h +164 -0
- data/src/core/lib/{security/credentials/google_default/credentials_windows.c → channel/handshaker_factory.c} +16 -23
- data/src/core/lib/channel/handshaker_factory.h +66 -0
- data/src/core/lib/channel/handshaker_registry.c +113 -0
- data/src/core/{ext/client_config/client_config.h → lib/channel/handshaker_registry.h} +26 -16
- data/src/core/lib/channel/http_client_filter.c +248 -46
- data/src/core/lib/channel/http_client_filter.h +3 -0
- data/src/core/lib/channel/http_server_filter.c +136 -24
- data/src/core/lib/channel/message_size_filter.c +261 -0
- data/src/core/lib/channel/message_size_filter.h +39 -0
- data/src/core/lib/compression/message_compress.c +43 -37
- data/src/core/lib/compression/message_compress.h +7 -5
- data/src/core/lib/http/format_request.c +26 -11
- data/src/core/lib/http/format_request.h +7 -5
- data/src/core/lib/http/httpcli.c +45 -27
- data/src/core/lib/http/httpcli.h +4 -4
- data/src/core/lib/http/httpcli_security_connector.c +56 -46
- data/src/core/lib/http/parser.c +17 -14
- data/src/core/lib/http/parser.h +4 -2
- data/src/core/lib/iomgr/closure.c +49 -7
- data/src/core/lib/iomgr/closure.h +56 -14
- data/src/core/lib/iomgr/combiner.c +422 -0
- data/src/core/lib/iomgr/combiner.h +64 -0
- data/src/core/lib/iomgr/endpoint.c +8 -2
- data/src/core/lib/iomgr/endpoint.h +17 -7
- data/src/core/lib/iomgr/endpoint_pair.h +3 -2
- data/src/core/lib/iomgr/endpoint_pair_posix.c +9 -8
- data/src/core/{ext/client_config/lb_policy_factory.c → lib/iomgr/endpoint_pair_uv.c} +18 -13
- data/src/core/lib/iomgr/endpoint_pair_windows.c +7 -6
- data/src/core/lib/iomgr/error.c +72 -6
- data/src/core/lib/iomgr/error.h +30 -3
- data/src/core/lib/iomgr/ev_epoll_linux.c +500 -382
- data/src/core/lib/iomgr/ev_epoll_linux.h +3 -2
- data/src/core/lib/iomgr/ev_poll_posix.c +317 -30
- data/src/core/lib/iomgr/ev_poll_posix.h +1 -0
- data/src/core/lib/iomgr/ev_posix.c +26 -5
- data/src/core/lib/iomgr/ev_posix.h +12 -1
- data/src/core/lib/iomgr/exec_ctx.c +27 -94
- data/src/core/lib/iomgr/exec_ctx.h +19 -22
- data/src/core/lib/iomgr/executor.c +29 -8
- data/src/core/lib/iomgr/executor.h +2 -4
- data/src/core/lib/iomgr/iocp_windows.c +3 -4
- data/src/core/lib/iomgr/iomgr.c +14 -10
- data/src/core/lib/iomgr/iomgr.h +6 -2
- data/src/core/lib/iomgr/iomgr_posix.c +2 -2
- data/src/core/lib/iomgr/iomgr_uv.c +49 -0
- data/src/core/lib/iomgr/iomgr_windows.c +2 -2
- data/src/core/lib/iomgr/load_file.c +3 -3
- data/src/core/lib/iomgr/load_file.h +2 -2
- data/src/core/lib/iomgr/network_status_tracker.c +1 -1
- data/src/core/lib/iomgr/pollset_set_uv.c +62 -0
- data/src/core/lib/iomgr/pollset_set_windows.c +3 -3
- data/src/core/lib/iomgr/pollset_uv.c +142 -0
- data/src/core/lib/iomgr/pollset_uv.h +42 -0
- data/src/core/lib/iomgr/pollset_windows.c +5 -6
- data/src/core/lib/iomgr/port.h +129 -0
- data/src/core/lib/iomgr/resolve_address.h +2 -1
- data/src/core/lib/iomgr/resolve_address_posix.c +14 -13
- data/src/core/lib/iomgr/resolve_address_uv.c +233 -0
- data/src/core/lib/iomgr/resolve_address_windows.c +14 -12
- data/src/core/lib/iomgr/resource_quota.c +832 -0
- data/src/core/lib/iomgr/resource_quota.h +159 -0
- data/src/core/lib/iomgr/sockaddr.h +10 -2
- data/src/core/lib/iomgr/sockaddr_utils.c +63 -36
- data/src/core/lib/iomgr/sockaddr_utils.h +14 -14
- data/src/core/lib/iomgr/socket_mutator.c +98 -0
- data/src/core/lib/iomgr/socket_mutator.h +80 -0
- data/src/core/lib/iomgr/socket_utils.h +42 -0
- data/src/core/lib/iomgr/socket_utils_common_posix.c +28 -13
- data/src/core/lib/iomgr/socket_utils_linux.c +11 -5
- data/src/core/lib/iomgr/socket_utils_posix.c +10 -7
- data/src/core/lib/iomgr/socket_utils_posix.h +11 -4
- data/src/core/lib/iomgr/socket_utils_uv.c +49 -0
- data/src/core/lib/iomgr/socket_utils_windows.c +52 -0
- data/src/core/lib/iomgr/socket_windows.c +14 -6
- data/src/core/lib/iomgr/socket_windows.h +1 -0
- data/src/core/lib/iomgr/tcp_client.h +8 -2
- data/src/core/lib/iomgr/tcp_client_posix.c +131 -82
- data/src/core/lib/iomgr/tcp_client_posix.h +45 -0
- data/src/core/lib/iomgr/tcp_client_uv.c +190 -0
- data/src/core/lib/iomgr/tcp_client_windows.c +54 -30
- data/src/core/lib/iomgr/tcp_posix.c +135 -56
- data/src/core/lib/iomgr/tcp_posix.h +2 -2
- data/src/core/lib/iomgr/tcp_server.h +14 -6
- data/src/core/lib/iomgr/tcp_server_posix.c +154 -118
- data/src/core/lib/iomgr/tcp_server_uv.c +388 -0
- data/src/core/lib/iomgr/tcp_server_windows.c +127 -100
- data/src/core/lib/iomgr/tcp_uv.c +367 -0
- data/src/core/lib/iomgr/tcp_uv.h +59 -0
- data/src/core/lib/iomgr/tcp_windows.c +65 -48
- data/src/core/lib/iomgr/tcp_windows.h +3 -1
- data/src/core/lib/iomgr/timer.h +21 -21
- data/src/core/lib/iomgr/{timer.c → timer_generic.c} +15 -10
- data/src/core/lib/iomgr/timer_generic.h +49 -0
- data/src/core/lib/iomgr/timer_heap.c +6 -0
- data/src/core/lib/iomgr/timer_uv.c +99 -0
- data/src/core/lib/iomgr/timer_uv.h +47 -0
- data/src/core/lib/iomgr/udp_server.c +116 -98
- data/src/core/lib/iomgr/udp_server.h +5 -3
- data/src/core/lib/iomgr/unix_sockets_posix.c +14 -6
- data/src/core/lib/iomgr/unix_sockets_posix.h +6 -5
- data/src/core/lib/iomgr/unix_sockets_posix_noop.c +4 -4
- data/src/core/lib/iomgr/wakeup_fd_cv.c +118 -0
- data/src/core/lib/iomgr/wakeup_fd_cv.h +80 -0
- data/src/core/lib/iomgr/wakeup_fd_eventfd.c +3 -3
- data/src/core/lib/iomgr/wakeup_fd_nospecial.c +3 -3
- data/src/core/lib/iomgr/wakeup_fd_pipe.c +12 -6
- data/src/core/lib/iomgr/wakeup_fd_posix.c +34 -5
- data/src/core/lib/iomgr/wakeup_fd_posix.h +5 -0
- data/src/core/lib/iomgr/workqueue.h +12 -20
- data/src/core/{ext/client_config/client_config.c → lib/iomgr/workqueue_uv.c} +24 -33
- data/{include/grpc/support/slice.h → src/core/lib/iomgr/workqueue_uv.h} +4 -6
- data/src/core/lib/iomgr/workqueue_windows.c +9 -8
- data/src/core/lib/json/json.c +3 -3
- data/src/core/lib/json/json.h +11 -11
- data/src/core/lib/json/json_reader.c +9 -5
- data/src/core/lib/profiling/basic_timers.c +10 -1
- data/src/core/lib/profiling/timers.h +2 -0
- data/src/core/lib/security/context/security_context.c +13 -3
- data/src/core/lib/security/context/security_context.h +20 -0
- data/src/core/lib/security/credentials/composite/composite_credentials.c +28 -14
- data/src/core/lib/security/credentials/composite/composite_credentials.h +2 -2
- data/src/core/lib/security/credentials/credentials.c +48 -19
- data/src/core/lib/security/credentials/credentials.h +36 -19
- data/src/core/lib/security/credentials/credentials_metadata.c +11 -8
- data/src/core/lib/security/credentials/fake/fake_credentials.c +15 -11
- data/src/core/lib/security/credentials/google_default/{credentials_posix.c → credentials_generic.c} +7 -14
- data/src/core/lib/security/credentials/google_default/google_default_credentials.c +33 -21
- data/src/core/lib/security/credentials/google_default/google_default_credentials.h +14 -0
- data/src/core/lib/security/credentials/iam/iam_credentials.c +3 -2
- data/src/core/lib/security/credentials/jwt/json_token.c +1 -0
- data/src/core/lib/security/credentials/jwt/json_token.h +1 -1
- data/src/core/lib/security/credentials/jwt/jwt_credentials.c +54 -19
- data/src/core/lib/security/credentials/jwt/jwt_credentials.h +2 -1
- data/src/core/lib/security/credentials/jwt/jwt_verifier.c +129 -79
- data/src/core/lib/security/credentials/jwt/jwt_verifier.h +9 -6
- data/src/core/lib/security/credentials/oauth2/oauth2_credentials.c +63 -28
- data/src/core/lib/security/credentials/oauth2/oauth2_credentials.h +1 -1
- data/src/core/lib/security/credentials/plugin/plugin_credentials.c +32 -11
- data/src/core/lib/security/credentials/ssl/ssl_credentials.c +13 -9
- data/src/core/lib/security/transport/client_auth_filter.c +33 -27
- data/src/core/lib/security/transport/secure_endpoint.c +93 -68
- data/src/core/lib/security/transport/secure_endpoint.h +2 -2
- data/src/core/lib/security/transport/security_connector.c +133 -168
- data/src/core/lib/security/transport/security_connector.h +31 -46
- data/src/core/lib/security/transport/security_handshaker.c +501 -0
- data/src/core/lib/security/transport/{handshake.h → security_handshaker.h} +10 -10
- data/src/core/lib/security/transport/server_auth_filter.c +50 -38
- data/src/core/lib/security/util/b64.c +11 -8
- data/src/core/lib/security/util/b64.h +5 -4
- data/src/core/lib/slice/percent_encoding.c +182 -0
- data/src/core/lib/slice/percent_encoding.h +78 -0
- data/src/core/lib/{support → slice}/slice.c +81 -50
- data/src/core/lib/{support → slice}/slice_buffer.c +78 -60
- data/src/core/lib/slice/slice_internal.h +49 -0
- data/src/core/lib/slice/slice_string_helpers.c +90 -0
- data/src/core/lib/{iomgr/workqueue_posix.h → slice/slice_string_helpers.h} +18 -18
- data/src/core/lib/support/backoff.c +24 -13
- data/src/core/lib/support/backoff.h +5 -2
- data/src/core/lib/support/env.h +0 -2
- data/src/core/lib/support/log.c +5 -4
- data/src/core/lib/support/log_linux.c +0 -1
- data/src/core/lib/support/log_posix.c +1 -1
- data/src/core/lib/support/mpscq.c +83 -0
- data/src/core/lib/support/mpscq.h +65 -0
- data/src/core/lib/support/string.c +58 -49
- data/src/core/lib/support/string.h +11 -8
- data/src/core/lib/support/subprocess_posix.c +5 -2
- data/src/core/lib/support/thd.c +1 -1
- data/src/core/lib/support/time.c +43 -79
- data/src/core/lib/support/time_posix.c +1 -1
- data/src/core/lib/support/tmpfile.h +0 -2
- data/src/core/lib/surface/alarm.c +4 -1
- data/src/core/lib/surface/byte_buffer.c +17 -11
- data/src/core/lib/surface/byte_buffer_reader.c +23 -15
- data/src/core/lib/surface/call.c +294 -276
- data/src/core/lib/surface/call.h +24 -9
- data/src/core/lib/surface/call_log_batch.c +5 -3
- data/src/core/lib/surface/channel.c +127 -111
- data/src/core/lib/surface/channel.h +14 -5
- data/src/core/lib/surface/channel_init.c +1 -1
- data/src/core/lib/surface/channel_init.h +10 -1
- data/src/core/lib/surface/channel_ping.c +7 -6
- data/src/core/lib/surface/completion_queue.c +154 -18
- data/src/core/lib/surface/completion_queue.h +5 -0
- data/src/core/lib/surface/init.c +40 -6
- data/src/core/lib/surface/init.h +1 -0
- data/src/core/lib/surface/init_secure.c +5 -2
- data/src/core/lib/surface/lame_client.c +28 -18
- data/src/core/lib/surface/server.c +134 -87
- data/src/core/lib/surface/server.h +8 -0
- data/src/core/lib/surface/validate_metadata.c +1 -1
- data/src/core/lib/surface/version.c +3 -1
- data/src/core/lib/transport/byte_stream.c +7 -4
- data/src/core/lib/transport/byte_stream.h +6 -10
- data/src/core/lib/transport/connectivity_state.c +21 -12
- data/src/core/lib/transport/connectivity_state.h +4 -1
- data/src/core/lib/transport/mdstr_hash_table.c +118 -0
- data/src/core/lib/transport/mdstr_hash_table.h +77 -0
- data/src/core/lib/transport/metadata.c +83 -60
- data/src/core/lib/transport/metadata.h +41 -23
- data/src/core/lib/transport/metadata_batch.c +17 -11
- data/src/core/lib/transport/metadata_batch.h +20 -6
- data/src/core/lib/transport/pid_controller.c +57 -0
- data/src/core/lib/transport/pid_controller.h +64 -0
- data/src/core/lib/transport/service_config.c +251 -0
- data/src/core/lib/transport/service_config.h +71 -0
- data/src/core/lib/transport/static_metadata.c +18 -16
- data/src/core/lib/transport/static_metadata.h +113 -107
- data/src/core/{ext/transport/chttp2 → lib}/transport/timeout_encoding.c +3 -3
- data/src/core/{ext/transport/chttp2 → lib}/transport/timeout_encoding.h +7 -7
- data/src/core/lib/transport/transport.c +84 -23
- data/src/core/lib/transport/transport.h +53 -8
- data/src/core/lib/transport/transport_impl.h +3 -0
- data/src/core/lib/transport/transport_op_string.c +92 -20
- data/src/core/lib/tsi/ssl_transport_security.c +3 -1
- data/src/core/plugin_registry/grpc_plugin_registry.c +8 -4
- data/src/ruby/ext/grpc/extconf.rb +0 -1
- data/src/ruby/ext/grpc/rb_byte_buffer.c +8 -7
- data/src/ruby/ext/grpc/rb_call.c +15 -5
- data/src/ruby/ext/grpc/rb_channel.c +1 -1
- data/src/ruby/ext/grpc/rb_compression_options.c +466 -0
- data/src/{core/ext/client_config/default_initial_connect_string.c → ruby/ext/grpc/rb_compression_options.h} +10 -5
- data/src/ruby/ext/grpc/rb_grpc.c +3 -1
- data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +198 -190
- data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +306 -294
- data/src/ruby/ext/grpc/rb_server.c +18 -12
- data/src/ruby/lib/grpc/errors.rb +154 -2
- data/src/ruby/lib/grpc/generic/active_call.rb +144 -63
- data/src/ruby/lib/grpc/generic/bidi_call.rb +18 -2
- data/src/ruby/lib/grpc/generic/client_stub.rb +7 -5
- data/src/ruby/lib/grpc/generic/rpc_desc.rb +39 -13
- data/src/ruby/lib/grpc/generic/rpc_server.rb +51 -24
- data/src/ruby/lib/grpc/generic/service.rb +3 -2
- data/src/ruby/lib/grpc/version.rb +1 -1
- data/src/ruby/pb/grpc/health/checker.rb +3 -1
- data/src/ruby/pb/src/proto/grpc/testing/test_services_pb.rb +7 -0
- data/src/ruby/pb/test/client.rb +307 -7
- data/src/ruby/pb/test/server.rb +26 -1
- data/src/ruby/spec/compression_options_spec.rb +164 -0
- data/src/ruby/spec/error_sanity_spec.rb +64 -0
- data/src/ruby/spec/generic/active_call_spec.rb +290 -12
- data/src/ruby/spec/generic/client_stub_spec.rb +91 -41
- data/src/ruby/spec/generic/rpc_desc_spec.rb +36 -16
- data/src/ruby/spec/generic/rpc_server_pool_spec.rb +22 -28
- data/src/ruby/spec/generic/rpc_server_spec.rb +6 -6
- data/src/ruby/spec/pb/health/checker_spec.rb +27 -19
- data/src/ruby/spec/spec_helper.rb +2 -0
- data/third_party/boringssl/crypto/aes/aes.c +12 -12
- data/third_party/boringssl/crypto/aes/mode_wrappers.c +6 -2
- data/third_party/boringssl/crypto/asn1/a_d2i_fp.c +28 -13
- data/third_party/boringssl/crypto/asn1/a_gentm.c +2 -0
- data/third_party/boringssl/crypto/asn1/a_object.c +7 -3
- data/third_party/boringssl/crypto/asn1/a_strnid.c +1 -0
- data/third_party/boringssl/crypto/asn1/a_time.c +0 -11
- data/third_party/boringssl/crypto/asn1/a_type.c +0 -2
- data/third_party/boringssl/crypto/asn1/a_utctm.c +1 -30
- data/third_party/boringssl/crypto/asn1/asn1_lib.c +56 -76
- data/third_party/boringssl/crypto/asn1/asn1_locl.h +0 -10
- data/third_party/boringssl/crypto/asn1/asn1_par.c +0 -322
- data/third_party/boringssl/crypto/asn1/f_enum.c +1 -108
- data/third_party/boringssl/crypto/asn1/f_int.c +1 -106
- data/third_party/boringssl/crypto/asn1/f_string.c +1 -106
- data/third_party/boringssl/crypto/asn1/tasn_dec.c +10 -14
- data/third_party/boringssl/crypto/asn1/tasn_enc.c +17 -11
- data/third_party/boringssl/crypto/asn1/tasn_typ.c +29 -42
- data/third_party/boringssl/crypto/asn1/tasn_utl.c +1 -1
- data/third_party/boringssl/crypto/base64/base64.c +249 -285
- data/third_party/boringssl/crypto/bio/bio.c +13 -23
- data/third_party/boringssl/crypto/bio/bio_mem.c +3 -2
- data/third_party/boringssl/crypto/bio/connect.c +12 -3
- data/third_party/boringssl/crypto/bio/fd.c +22 -15
- data/third_party/boringssl/crypto/bio/file.c +2 -38
- data/third_party/boringssl/crypto/bio/hexdump.c +1 -2
- data/third_party/boringssl/crypto/bio/internal.h +3 -0
- data/third_party/boringssl/crypto/bio/pair.c +1 -1
- data/third_party/boringssl/crypto/bio/socket.c +10 -2
- data/third_party/boringssl/crypto/bio/socket_helper.c +2 -2
- data/third_party/boringssl/crypto/bn/asm/x86_64-gcc.c +0 -8
- data/third_party/boringssl/crypto/bn/bn.c +38 -0
- data/third_party/boringssl/crypto/bn/cmp.c +25 -0
- data/third_party/boringssl/crypto/bn/convert.c +73 -76
- data/third_party/boringssl/crypto/bn/div.c +136 -70
- data/third_party/boringssl/crypto/bn/exponentiation.c +86 -381
- data/third_party/boringssl/crypto/bn/gcd.c +213 -296
- data/third_party/boringssl/crypto/bn/generic.c +0 -80
- data/third_party/boringssl/crypto/bn/internal.h +15 -3
- data/third_party/boringssl/crypto/bn/montgomery.c +57 -207
- data/third_party/boringssl/crypto/bn/montgomery_inv.c +160 -0
- data/third_party/boringssl/crypto/bn/mul.c +2 -1
- data/third_party/boringssl/crypto/bn/prime.c +24 -8
- data/third_party/boringssl/crypto/bn/random.c +47 -33
- data/third_party/boringssl/crypto/bn/sqrt.c +4 -5
- data/third_party/boringssl/crypto/buf/buf.c +25 -21
- data/third_party/boringssl/crypto/bytestring/ber.c +1 -0
- data/third_party/boringssl/crypto/bytestring/cbb.c +50 -22
- data/third_party/boringssl/crypto/bytestring/cbs.c +28 -4
- data/third_party/boringssl/crypto/chacha/{chacha_generic.c → chacha.c} +56 -29
- data/third_party/boringssl/crypto/cipher/aead.c +11 -22
- data/third_party/boringssl/crypto/cipher/cipher.c +2 -2
- data/third_party/boringssl/crypto/cipher/e_aes.c +53 -103
- data/third_party/boringssl/crypto/cipher/e_chacha20poly1305.c +2 -8
- data/third_party/boringssl/crypto/cipher/e_des.c +3 -5
- data/third_party/boringssl/crypto/cipher/e_null.c +1 -1
- data/third_party/boringssl/crypto/cipher/e_rc2.c +1 -1
- data/third_party/boringssl/crypto/cipher/e_rc4.c +1 -1
- data/third_party/boringssl/crypto/cipher/e_ssl3.c +3 -63
- data/third_party/boringssl/crypto/cipher/e_tls.c +12 -83
- data/third_party/boringssl/crypto/cipher/internal.h +8 -10
- data/third_party/boringssl/crypto/cipher/tls_cbc.c +69 -40
- data/third_party/boringssl/crypto/conf/conf.c +2 -1
- data/third_party/boringssl/crypto/cpu-aarch64-linux.c +61 -0
- data/third_party/boringssl/crypto/cpu-arm-linux.c +360 -0
- data/third_party/boringssl/crypto/cpu-arm.c +0 -161
- data/third_party/boringssl/crypto/cpu-intel.c +5 -3
- data/third_party/boringssl/{ssl/test/scoped_types.h → crypto/cpu-ppc64le.c} +21 -9
- data/third_party/boringssl/crypto/crypto.c +29 -7
- data/third_party/boringssl/crypto/curve25519/curve25519.c +284 -242
- data/third_party/boringssl/crypto/curve25519/internal.h +64 -0
- data/third_party/boringssl/crypto/curve25519/spake25519.c +464 -0
- data/third_party/boringssl/crypto/curve25519/x25519-x86_64.c +21 -0
- data/third_party/boringssl/crypto/dh/check.c +22 -6
- data/third_party/boringssl/crypto/dh/dh.c +45 -21
- data/third_party/boringssl/crypto/dh/dh_asn1.c +96 -20
- data/third_party/boringssl/crypto/dh/params.c +30 -78
- data/third_party/boringssl/crypto/digest/digest.c +3 -3
- data/third_party/boringssl/crypto/dsa/dsa.c +59 -29
- data/third_party/boringssl/crypto/dsa/dsa_asn1.c +4 -0
- data/third_party/boringssl/crypto/ec/ec.c +84 -140
- data/third_party/boringssl/crypto/ec/ec_asn1.c +82 -52
- data/third_party/boringssl/crypto/ec/ec_key.c +15 -15
- data/third_party/boringssl/crypto/ec/ec_montgomery.c +87 -50
- data/third_party/boringssl/crypto/ec/internal.h +12 -36
- data/third_party/boringssl/crypto/ec/oct.c +11 -11
- data/third_party/boringssl/crypto/ec/p224-64.c +59 -116
- data/third_party/boringssl/crypto/ec/p256-64.c +88 -163
- data/third_party/boringssl/crypto/ec/p256-x86_64.c +46 -58
- data/third_party/boringssl/crypto/ec/simple.c +81 -201
- data/third_party/boringssl/crypto/ec/util-64.c +0 -74
- data/third_party/boringssl/crypto/ecdh/ecdh.c +7 -1
- data/third_party/boringssl/crypto/ecdsa/ecdsa.c +28 -46
- data/third_party/boringssl/crypto/ecdsa/ecdsa_asn1.c +1 -0
- data/third_party/boringssl/crypto/engine/engine.c +1 -1
- data/third_party/boringssl/crypto/err/err.c +3 -3
- data/third_party/boringssl/crypto/evp/evp.c +14 -59
- data/third_party/boringssl/crypto/evp/evp_asn1.c +144 -87
- data/third_party/boringssl/crypto/evp/evp_ctx.c +7 -7
- data/third_party/boringssl/crypto/evp/internal.h +4 -46
- data/third_party/boringssl/crypto/evp/p_dsa_asn1.c +8 -157
- data/third_party/boringssl/crypto/evp/p_ec.c +1 -1
- data/third_party/boringssl/crypto/evp/p_ec_asn1.c +22 -170
- data/third_party/boringssl/crypto/evp/p_rsa.c +1 -1
- data/third_party/boringssl/crypto/evp/p_rsa_asn1.c +10 -548
- data/third_party/boringssl/crypto/evp/print.c +520 -0
- data/third_party/boringssl/crypto/ex_data.c +4 -6
- data/third_party/boringssl/crypto/hkdf/hkdf.c +38 -17
- data/third_party/boringssl/crypto/hmac/hmac.c +6 -6
- data/third_party/boringssl/crypto/internal.h +57 -77
- data/third_party/boringssl/crypto/lhash/lhash.c +6 -10
- data/third_party/boringssl/crypto/md4/md4.c +9 -0
- data/third_party/boringssl/crypto/mem.c +19 -19
- data/third_party/boringssl/crypto/modes/cfb.c +5 -6
- data/third_party/boringssl/crypto/modes/ctr.c +10 -18
- data/third_party/boringssl/crypto/modes/gcm.c +100 -66
- data/third_party/boringssl/crypto/modes/internal.h +15 -27
- data/third_party/boringssl/crypto/modes/ofb.c +9 -22
- data/third_party/boringssl/crypto/newhope/error_correction.c +131 -0
- data/third_party/boringssl/crypto/newhope/internal.h +71 -0
- data/third_party/boringssl/crypto/newhope/newhope.c +174 -0
- data/third_party/boringssl/crypto/newhope/ntt.c +148 -0
- data/third_party/boringssl/crypto/newhope/poly.c +183 -0
- data/third_party/boringssl/crypto/newhope/precomp.c +306 -0
- data/third_party/boringssl/crypto/newhope/reduce.c +42 -0
- data/third_party/boringssl/crypto/obj/obj.c +111 -135
- data/third_party/boringssl/crypto/obj/obj_dat.h +4 -10
- data/third_party/boringssl/crypto/pem/pem_lib.c +6 -43
- data/third_party/boringssl/crypto/pem/pem_pkey.c +10 -19
- data/third_party/boringssl/crypto/pkcs8/p5_pbe.c +1 -0
- data/third_party/boringssl/crypto/pkcs8/p5_pbev2.c +2 -1
- data/third_party/boringssl/crypto/pkcs8/p8_pkey.c +2 -2
- data/third_party/boringssl/crypto/pkcs8/pkcs8.c +95 -87
- data/third_party/boringssl/crypto/{test/test_util.h → poly1305/internal.h} +15 -10
- data/third_party/boringssl/crypto/poly1305/poly1305.c +8 -15
- data/third_party/boringssl/crypto/poly1305/poly1305_arm.c +1 -0
- data/third_party/boringssl/crypto/poly1305/poly1305_vec.c +3 -3
- data/third_party/boringssl/crypto/rand/deterministic.c +47 -0
- data/third_party/boringssl/crypto/rand/rand.c +4 -1
- data/third_party/boringssl/crypto/rand/urandom.c +5 -7
- data/third_party/boringssl/crypto/rand/windows.c +5 -8
- data/third_party/boringssl/crypto/rc4/rc4.c +24 -209
- data/third_party/boringssl/crypto/refcount_lock.c +2 -2
- data/third_party/boringssl/crypto/rsa/blinding.c +74 -232
- data/third_party/boringssl/crypto/rsa/internal.h +5 -13
- data/third_party/boringssl/crypto/rsa/padding.c +64 -63
- data/third_party/boringssl/crypto/rsa/rsa.c +50 -28
- data/third_party/boringssl/crypto/rsa/rsa_asn1.c +8 -16
- data/third_party/boringssl/crypto/rsa/rsa_impl.c +134 -122
- data/third_party/boringssl/crypto/sha/sha256.c +2 -2
- data/third_party/boringssl/crypto/sha/sha512.c +7 -7
- data/third_party/boringssl/crypto/stack/stack.c +13 -22
- data/third_party/boringssl/crypto/thread.c +21 -12
- data/third_party/boringssl/crypto/thread_none.c +6 -2
- data/third_party/boringssl/crypto/thread_pthread.c +16 -7
- data/third_party/boringssl/crypto/thread_win.c +38 -85
- data/third_party/boringssl/crypto/x509/a_sign.c +3 -3
- data/third_party/boringssl/crypto/x509/a_strex.c +1 -1
- data/third_party/boringssl/crypto/x509/a_verify.c +2 -2
- data/third_party/boringssl/crypto/{evp → x509}/algorithm.c +37 -53
- data/third_party/boringssl/crypto/x509/asn1_gen.c +1 -2
- data/third_party/boringssl/crypto/x509/by_dir.c +6 -6
- data/third_party/boringssl/crypto/x509/internal.h +66 -0
- data/third_party/boringssl/crypto/x509/rsa_pss.c +385 -0
- data/third_party/boringssl/crypto/x509/t_x509.c +10 -12
- data/third_party/boringssl/crypto/x509/x509.c +5 -0
- data/third_party/boringssl/crypto/x509/x509_att.c +9 -3
- data/third_party/boringssl/crypto/x509/x509_lu.c +34 -44
- data/third_party/boringssl/crypto/x509/x509_obj.c +19 -2
- data/third_party/boringssl/crypto/x509/x509_r2x.c +9 -5
- data/third_party/boringssl/crypto/x509/x509_set.c +5 -0
- data/third_party/boringssl/crypto/x509/x509_txt.c +5 -0
- data/third_party/boringssl/crypto/x509/x509_vfy.c +63 -32
- data/third_party/boringssl/crypto/x509/x509_vpm.c +29 -18
- data/third_party/boringssl/crypto/x509/x509cset.c +2 -1
- data/third_party/boringssl/crypto/x509/x_crl.c +2 -2
- data/third_party/boringssl/crypto/x509/x_name.c +14 -17
- data/third_party/boringssl/crypto/x509/x_pubkey.c +10 -7
- data/third_party/boringssl/crypto/x509/x_x509.c +67 -6
- data/third_party/boringssl/crypto/x509v3/pcy_cache.c +2 -2
- data/third_party/boringssl/crypto/x509v3/pcy_tree.c +2 -1
- data/third_party/boringssl/crypto/x509v3/v3_conf.c +4 -3
- data/third_party/boringssl/crypto/x509v3/v3_cpols.c +5 -0
- data/third_party/boringssl/crypto/x509v3/v3_prn.c +0 -3
- data/third_party/boringssl/crypto/x509v3/v3_purp.c +2 -2
- data/third_party/boringssl/crypto/x509v3/v3_utl.c +2 -1
- data/third_party/boringssl/include/openssl/aead.h +72 -73
- data/third_party/boringssl/include/openssl/arm_arch.h +0 -6
- data/third_party/boringssl/include/openssl/asn1.h +103 -235
- data/third_party/boringssl/include/openssl/asn1_mac.h +17 -74
- data/third_party/boringssl/include/openssl/asn1t.h +1 -11
- data/third_party/boringssl/include/openssl/base.h +145 -3
- data/third_party/boringssl/include/openssl/base64.h +20 -17
- data/third_party/boringssl/include/openssl/bio.h +59 -34
- data/third_party/boringssl/include/openssl/bn.h +118 -51
- data/third_party/boringssl/include/openssl/buf.h +15 -0
- data/third_party/boringssl/include/openssl/bytestring.h +52 -4
- data/third_party/boringssl/include/openssl/chacha.h +2 -2
- data/third_party/boringssl/include/openssl/cipher.h +18 -1
- data/third_party/boringssl/include/openssl/cmac.h +11 -0
- data/third_party/boringssl/include/openssl/conf.h +13 -2
- data/third_party/boringssl/include/openssl/cpu.h +20 -23
- data/third_party/boringssl/include/openssl/crypto.h +22 -1
- data/third_party/boringssl/include/openssl/curve25519.h +96 -4
- data/third_party/boringssl/include/openssl/dh.h +71 -16
- data/third_party/boringssl/include/openssl/digest.h +38 -11
- data/third_party/boringssl/include/openssl/dsa.h +40 -4
- data/third_party/boringssl/include/openssl/ec.h +44 -18
- data/third_party/boringssl/include/openssl/ec_key.h +27 -6
- data/third_party/boringssl/include/openssl/ecdsa.h +11 -0
- data/third_party/boringssl/include/openssl/engine.h +11 -0
- data/third_party/boringssl/include/openssl/evp.h +52 -88
- data/third_party/boringssl/include/openssl/hkdf.h +24 -4
- data/third_party/boringssl/include/openssl/hmac.h +20 -6
- data/third_party/boringssl/include/openssl/md4.h +4 -0
- data/third_party/boringssl/include/openssl/mem.h +19 -0
- data/third_party/boringssl/include/openssl/newhope.h +158 -0
- data/third_party/boringssl/include/openssl/nid.h +4166 -0
- data/third_party/boringssl/include/openssl/obj.h +31 -3
- data/third_party/boringssl/include/openssl/obj_mac.h +17 -4143
- data/third_party/boringssl/include/openssl/{opensslfeatures.h → opensslconf.h} +3 -3
- data/third_party/boringssl/include/openssl/pem.h +5 -0
- data/third_party/boringssl/include/openssl/pkcs8.h +12 -0
- data/third_party/boringssl/include/openssl/rand.h +6 -0
- data/third_party/boringssl/include/openssl/rc4.h +6 -0
- data/third_party/boringssl/{crypto/dh/internal.h → include/openssl/ripemd.h} +38 -11
- data/third_party/boringssl/include/openssl/rsa.h +127 -65
- data/third_party/boringssl/include/openssl/sha.h +14 -10
- data/third_party/boringssl/include/openssl/ssl.h +561 -275
- data/third_party/boringssl/include/openssl/ssl3.h +18 -25
- data/third_party/boringssl/include/openssl/stack.h +2 -4
- data/third_party/boringssl/include/openssl/stack_macros.h +321 -353
- data/third_party/boringssl/include/openssl/thread.h +31 -13
- data/third_party/boringssl/include/openssl/time_support.h +1 -0
- data/third_party/boringssl/include/openssl/tls1.h +37 -33
- data/third_party/boringssl/include/openssl/x509.h +69 -26
- data/third_party/boringssl/include/openssl/x509_vfy.h +12 -10
- data/third_party/boringssl/include/openssl/x509v3.h +23 -2
- data/third_party/boringssl/ssl/custom_extensions.c +3 -5
- data/third_party/boringssl/ssl/d1_both.c +463 -499
- data/third_party/boringssl/ssl/d1_lib.c +38 -109
- data/third_party/boringssl/ssl/d1_pkt.c +173 -334
- data/third_party/boringssl/ssl/d1_srtp.c +20 -18
- data/third_party/boringssl/ssl/{d1_meth.c → dtls_method.c} +88 -15
- data/third_party/boringssl/ssl/dtls_record.c +27 -26
- data/third_party/boringssl/ssl/{s3_clnt.c → handshake_client.c} +816 -904
- data/third_party/boringssl/ssl/handshake_server.c +1932 -0
- data/third_party/boringssl/ssl/internal.h +712 -439
- data/third_party/boringssl/ssl/s3_both.c +445 -257
- data/third_party/boringssl/ssl/s3_enc.c +53 -36
- data/third_party/boringssl/ssl/s3_lib.c +23 -268
- data/third_party/boringssl/ssl/s3_pkt.c +168 -364
- data/third_party/boringssl/ssl/ssl_aead_ctx.c +46 -17
- data/third_party/boringssl/ssl/ssl_asn1.c +56 -26
- data/third_party/boringssl/ssl/ssl_buffer.c +16 -24
- data/third_party/boringssl/ssl/ssl_cert.c +324 -49
- data/third_party/boringssl/ssl/ssl_cipher.c +205 -150
- data/third_party/boringssl/ssl/ssl_ecdh.c +287 -51
- data/third_party/boringssl/ssl/ssl_file.c +21 -68
- data/third_party/boringssl/ssl/ssl_lib.c +881 -510
- data/third_party/boringssl/ssl/ssl_rsa.c +404 -34
- data/third_party/boringssl/ssl/ssl_session.c +324 -103
- data/third_party/boringssl/ssl/ssl_stat.c +6 -88
- data/third_party/boringssl/ssl/t1_enc.c +23 -39
- data/third_party/boringssl/ssl/t1_lib.c +1120 -622
- data/third_party/boringssl/ssl/tls13_both.c +440 -0
- data/third_party/boringssl/ssl/tls13_client.c +682 -0
- data/third_party/boringssl/ssl/tls13_enc.c +391 -0
- data/third_party/boringssl/ssl/tls13_server.c +672 -0
- data/third_party/boringssl/ssl/{s3_meth.c → tls_method.c} +100 -21
- data/third_party/boringssl/ssl/tls_record.c +159 -77
- data/third_party/nanopb/pb.h +60 -28
- data/third_party/nanopb/pb_decode.c +120 -92
- data/third_party/nanopb/pb_decode.h +3 -3
- data/third_party/nanopb/pb_encode.c +73 -67
- data/third_party/nanopb/pb_encode.h +4 -4
- metadata +155 -89
- data/include/grpc/impl/codegen/byte_buffer.h +0 -122
- data/include/grpc/impl/codegen/log.h +0 -118
- data/include/grpc/impl/codegen/time.h +0 -130
- data/src/core/ext/client_config/client_channel.c +0 -593
- data/src/core/ext/client_config/subchannel_call_holder.c +0 -272
- data/src/core/ext/client_config/subchannel_call_holder.h +0 -99
- data/src/core/lib/iomgr/ev_poll_and_epoll_posix.c +0 -2046
- data/src/core/lib/iomgr/workqueue_posix.c +0 -151
- data/src/core/lib/security/transport/handshake.c +0 -368
- data/third_party/boringssl/crypto/asn1/a_bytes.c +0 -308
- data/third_party/boringssl/crypto/asn1/bio_asn1.c +0 -477
- data/third_party/boringssl/crypto/asn1/bio_ndef.c +0 -251
- data/third_party/boringssl/crypto/asn1/t_pkey.c +0 -110
- data/third_party/boringssl/crypto/asn1/tasn_prn.c +0 -596
- data/third_party/boringssl/crypto/chacha/chacha_vec.c +0 -328
- data/third_party/boringssl/crypto/directory.h +0 -66
- data/third_party/boringssl/crypto/directory_posix.c +0 -108
- data/third_party/boringssl/crypto/directory_win.c +0 -144
- data/third_party/boringssl/crypto/test/scoped_types.h +0 -140
- data/third_party/boringssl/include/openssl/pqueue.h +0 -146
- data/third_party/boringssl/ssl/d1_clnt.c +0 -561
- data/third_party/boringssl/ssl/d1_srvr.c +0 -476
- data/third_party/boringssl/ssl/pqueue/pqueue.c +0 -197
- data/third_party/boringssl/ssl/s3_srvr.c +0 -2272
- data/third_party/boringssl/ssl/test/async_bio.h +0 -45
- data/third_party/boringssl/ssl/test/packeted_bio.h +0 -44
- data/third_party/boringssl/ssl/test/test_config.h +0 -110
@@ -1,251 +0,0 @@
|
|
1
|
-
/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
|
2
|
-
* All rights reserved.
|
3
|
-
*
|
4
|
-
* This package is an SSL implementation written
|
5
|
-
* by Eric Young (eay@cryptsoft.com).
|
6
|
-
* The implementation was written so as to conform with Netscapes SSL.
|
7
|
-
*
|
8
|
-
* This library is free for commercial and non-commercial use as long as
|
9
|
-
* the following conditions are aheared to. The following conditions
|
10
|
-
* apply to all code found in this distribution, be it the RC4, RSA,
|
11
|
-
* lhash, DES, etc., code; not just the SSL code. The SSL documentation
|
12
|
-
* included with this distribution is covered by the same copyright terms
|
13
|
-
* except that the holder is Tim Hudson (tjh@cryptsoft.com).
|
14
|
-
*
|
15
|
-
* Copyright remains Eric Young's, and as such any Copyright notices in
|
16
|
-
* the code are not to be removed.
|
17
|
-
* If this package is used in a product, Eric Young should be given attribution
|
18
|
-
* as the author of the parts of the library used.
|
19
|
-
* This can be in the form of a textual message at program startup or
|
20
|
-
* in documentation (online or textual) provided with the package.
|
21
|
-
*
|
22
|
-
* Redistribution and use in source and binary forms, with or without
|
23
|
-
* modification, are permitted provided that the following conditions
|
24
|
-
* are met:
|
25
|
-
* 1. Redistributions of source code must retain the copyright
|
26
|
-
* notice, this list of conditions and the following disclaimer.
|
27
|
-
* 2. Redistributions in binary form must reproduce the above copyright
|
28
|
-
* notice, this list of conditions and the following disclaimer in the
|
29
|
-
* documentation and/or other materials provided with the distribution.
|
30
|
-
* 3. All advertising materials mentioning features or use of this software
|
31
|
-
* must display the following acknowledgement:
|
32
|
-
* "This product includes cryptographic software written by
|
33
|
-
* Eric Young (eay@cryptsoft.com)"
|
34
|
-
* The word 'cryptographic' can be left out if the rouines from the library
|
35
|
-
* being used are not cryptographic related :-).
|
36
|
-
* 4. If you include any Windows specific code (or a derivative thereof) from
|
37
|
-
* the apps directory (application code) you must include an acknowledgement:
|
38
|
-
* "This product includes software written by Tim Hudson (tjh@cryptsoft.com)"
|
39
|
-
*
|
40
|
-
* THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND
|
41
|
-
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
42
|
-
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
43
|
-
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
44
|
-
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
45
|
-
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
46
|
-
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
47
|
-
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
48
|
-
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
49
|
-
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
50
|
-
* SUCH DAMAGE.
|
51
|
-
*
|
52
|
-
* The licence and distribution terms for any publically available version or
|
53
|
-
* derivative of this code cannot be changed. i.e. this code cannot simply be
|
54
|
-
* copied and put under another distribution licence
|
55
|
-
* [including the GNU Public Licence.] */
|
56
|
-
|
57
|
-
#include <openssl/asn1.h>
|
58
|
-
|
59
|
-
#include <assert.h>
|
60
|
-
|
61
|
-
#include <openssl/asn1t.h>
|
62
|
-
#include <openssl/bio.h>
|
63
|
-
#include <openssl/err.h>
|
64
|
-
#include <openssl/mem.h>
|
65
|
-
|
66
|
-
/* Experimental NDEF ASN1 BIO support routines */
|
67
|
-
|
68
|
-
/*
|
69
|
-
* The usage is quite simple, initialize an ASN1 structure, get a BIO from it
|
70
|
-
* then any data written through the BIO will end up translated to
|
71
|
-
* approptiate format on the fly. The data is streamed out and does *not*
|
72
|
-
* need to be all held in memory at once. When the BIO is flushed the output
|
73
|
-
* is finalized and any signatures etc written out. The BIO is a 'proper'
|
74
|
-
* BIO and can handle non blocking I/O correctly. The usage is simple. The
|
75
|
-
* implementation is *not*...
|
76
|
-
*/
|
77
|
-
|
78
|
-
/* BIO support data stored in the ASN1 BIO ex_arg */
|
79
|
-
|
80
|
-
typedef struct ndef_aux_st {
|
81
|
-
/* ASN1 structure this BIO refers to */
|
82
|
-
ASN1_VALUE *val;
|
83
|
-
const ASN1_ITEM *it;
|
84
|
-
/* Top of the BIO chain */
|
85
|
-
BIO *ndef_bio;
|
86
|
-
/* Output BIO */
|
87
|
-
BIO *out;
|
88
|
-
/* Boundary where content is inserted */
|
89
|
-
unsigned char **boundary;
|
90
|
-
/* DER buffer start */
|
91
|
-
unsigned char *derbuf;
|
92
|
-
} NDEF_SUPPORT;
|
93
|
-
|
94
|
-
static int ndef_prefix(BIO *b, unsigned char **pbuf, int *plen, void *parg);
|
95
|
-
static int ndef_prefix_free(BIO *b, unsigned char **pbuf, int *plen,
|
96
|
-
void *parg);
|
97
|
-
static int ndef_suffix(BIO *b, unsigned char **pbuf, int *plen, void *parg);
|
98
|
-
static int ndef_suffix_free(BIO *b, unsigned char **pbuf, int *plen,
|
99
|
-
void *parg);
|
100
|
-
|
101
|
-
BIO *BIO_new_NDEF(BIO *out, ASN1_VALUE *val, const ASN1_ITEM *it)
|
102
|
-
{
|
103
|
-
NDEF_SUPPORT *ndef_aux = NULL;
|
104
|
-
BIO *asn_bio = NULL;
|
105
|
-
const ASN1_AUX *aux = it->funcs;
|
106
|
-
ASN1_STREAM_ARG sarg;
|
107
|
-
|
108
|
-
if (!aux || !aux->asn1_cb) {
|
109
|
-
OPENSSL_PUT_ERROR(ASN1, ASN1_R_STREAMING_NOT_SUPPORTED);
|
110
|
-
return NULL;
|
111
|
-
}
|
112
|
-
ndef_aux = OPENSSL_malloc(sizeof(NDEF_SUPPORT));
|
113
|
-
asn_bio = BIO_new(BIO_f_asn1());
|
114
|
-
|
115
|
-
/* ASN1 bio needs to be next to output BIO */
|
116
|
-
|
117
|
-
out = BIO_push(asn_bio, out);
|
118
|
-
|
119
|
-
if (!ndef_aux || !asn_bio || !out)
|
120
|
-
goto err;
|
121
|
-
|
122
|
-
BIO_asn1_set_prefix(asn_bio, ndef_prefix, ndef_prefix_free);
|
123
|
-
BIO_asn1_set_suffix(asn_bio, ndef_suffix, ndef_suffix_free);
|
124
|
-
|
125
|
-
/*
|
126
|
-
* Now let callback prepend any digest, cipher etc BIOs ASN1 structure
|
127
|
-
* needs.
|
128
|
-
*/
|
129
|
-
|
130
|
-
sarg.out = out;
|
131
|
-
sarg.ndef_bio = NULL;
|
132
|
-
sarg.boundary = NULL;
|
133
|
-
|
134
|
-
if (aux->asn1_cb(ASN1_OP_STREAM_PRE, &val, it, &sarg) <= 0)
|
135
|
-
goto err;
|
136
|
-
|
137
|
-
ndef_aux->val = val;
|
138
|
-
ndef_aux->it = it;
|
139
|
-
ndef_aux->ndef_bio = sarg.ndef_bio;
|
140
|
-
ndef_aux->boundary = sarg.boundary;
|
141
|
-
ndef_aux->out = out;
|
142
|
-
|
143
|
-
BIO_ctrl(asn_bio, BIO_C_SET_EX_ARG, 0, ndef_aux);
|
144
|
-
|
145
|
-
return sarg.ndef_bio;
|
146
|
-
|
147
|
-
err:
|
148
|
-
if (asn_bio)
|
149
|
-
BIO_free(asn_bio);
|
150
|
-
if (ndef_aux)
|
151
|
-
OPENSSL_free(ndef_aux);
|
152
|
-
return NULL;
|
153
|
-
}
|
154
|
-
|
155
|
-
static int ndef_prefix(BIO *b, unsigned char **pbuf, int *plen, void *parg)
|
156
|
-
{
|
157
|
-
NDEF_SUPPORT *ndef_aux;
|
158
|
-
unsigned char *p;
|
159
|
-
int derlen;
|
160
|
-
|
161
|
-
if (!parg)
|
162
|
-
return 0;
|
163
|
-
|
164
|
-
ndef_aux = *(NDEF_SUPPORT **)parg;
|
165
|
-
|
166
|
-
derlen = ASN1_item_ndef_i2d(ndef_aux->val, NULL, ndef_aux->it);
|
167
|
-
p = OPENSSL_malloc(derlen);
|
168
|
-
if (p == NULL)
|
169
|
-
return 0;
|
170
|
-
|
171
|
-
ndef_aux->derbuf = p;
|
172
|
-
*pbuf = p;
|
173
|
-
derlen = ASN1_item_ndef_i2d(ndef_aux->val, &p, ndef_aux->it);
|
174
|
-
|
175
|
-
if (!*ndef_aux->boundary)
|
176
|
-
return 0;
|
177
|
-
|
178
|
-
*plen = *ndef_aux->boundary - *pbuf;
|
179
|
-
|
180
|
-
return 1;
|
181
|
-
}
|
182
|
-
|
183
|
-
static int ndef_prefix_free(BIO *b, unsigned char **pbuf, int *plen,
|
184
|
-
void *parg)
|
185
|
-
{
|
186
|
-
NDEF_SUPPORT *ndef_aux;
|
187
|
-
|
188
|
-
if (!parg)
|
189
|
-
return 0;
|
190
|
-
|
191
|
-
ndef_aux = *(NDEF_SUPPORT **)parg;
|
192
|
-
|
193
|
-
if (ndef_aux->derbuf)
|
194
|
-
OPENSSL_free(ndef_aux->derbuf);
|
195
|
-
|
196
|
-
ndef_aux->derbuf = NULL;
|
197
|
-
*pbuf = NULL;
|
198
|
-
*plen = 0;
|
199
|
-
return 1;
|
200
|
-
}
|
201
|
-
|
202
|
-
static int ndef_suffix_free(BIO *b, unsigned char **pbuf, int *plen,
|
203
|
-
void *parg)
|
204
|
-
{
|
205
|
-
NDEF_SUPPORT **pndef_aux = (NDEF_SUPPORT **)parg;
|
206
|
-
if (!ndef_prefix_free(b, pbuf, plen, parg))
|
207
|
-
return 0;
|
208
|
-
OPENSSL_free(*pndef_aux);
|
209
|
-
*pndef_aux = NULL;
|
210
|
-
return 1;
|
211
|
-
}
|
212
|
-
|
213
|
-
static int ndef_suffix(BIO *b, unsigned char **pbuf, int *plen, void *parg)
|
214
|
-
{
|
215
|
-
NDEF_SUPPORT *ndef_aux;
|
216
|
-
unsigned char *p;
|
217
|
-
int derlen;
|
218
|
-
const ASN1_AUX *aux;
|
219
|
-
ASN1_STREAM_ARG sarg;
|
220
|
-
|
221
|
-
if (!parg)
|
222
|
-
return 0;
|
223
|
-
|
224
|
-
ndef_aux = *(NDEF_SUPPORT **)parg;
|
225
|
-
|
226
|
-
aux = ndef_aux->it->funcs;
|
227
|
-
|
228
|
-
/* Finalize structures */
|
229
|
-
sarg.ndef_bio = ndef_aux->ndef_bio;
|
230
|
-
sarg.out = ndef_aux->out;
|
231
|
-
sarg.boundary = ndef_aux->boundary;
|
232
|
-
if (aux->asn1_cb(ASN1_OP_STREAM_POST,
|
233
|
-
&ndef_aux->val, ndef_aux->it, &sarg) <= 0)
|
234
|
-
return 0;
|
235
|
-
|
236
|
-
derlen = ASN1_item_ndef_i2d(ndef_aux->val, NULL, ndef_aux->it);
|
237
|
-
p = OPENSSL_malloc(derlen);
|
238
|
-
if (p == NULL)
|
239
|
-
return 0;
|
240
|
-
|
241
|
-
ndef_aux->derbuf = p;
|
242
|
-
*pbuf = p;
|
243
|
-
derlen = ASN1_item_ndef_i2d(ndef_aux->val, &p, ndef_aux->it);
|
244
|
-
|
245
|
-
if (!*ndef_aux->boundary)
|
246
|
-
return 0;
|
247
|
-
*pbuf = *ndef_aux->boundary;
|
248
|
-
*plen = derlen - (*ndef_aux->boundary - ndef_aux->derbuf);
|
249
|
-
|
250
|
-
return 1;
|
251
|
-
}
|
@@ -1,110 +0,0 @@
|
|
1
|
-
/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
|
2
|
-
* All rights reserved.
|
3
|
-
*
|
4
|
-
* This package is an SSL implementation written
|
5
|
-
* by Eric Young (eay@cryptsoft.com).
|
6
|
-
* The implementation was written so as to conform with Netscapes SSL.
|
7
|
-
*
|
8
|
-
* This library is free for commercial and non-commercial use as long as
|
9
|
-
* the following conditions are aheared to. The following conditions
|
10
|
-
* apply to all code found in this distribution, be it the RC4, RSA,
|
11
|
-
* lhash, DES, etc., code; not just the SSL code. The SSL documentation
|
12
|
-
* included with this distribution is covered by the same copyright terms
|
13
|
-
* except that the holder is Tim Hudson (tjh@cryptsoft.com).
|
14
|
-
*
|
15
|
-
* Copyright remains Eric Young's, and as such any Copyright notices in
|
16
|
-
* the code are not to be removed.
|
17
|
-
* If this package is used in a product, Eric Young should be given attribution
|
18
|
-
* as the author of the parts of the library used.
|
19
|
-
* This can be in the form of a textual message at program startup or
|
20
|
-
* in documentation (online or textual) provided with the package.
|
21
|
-
*
|
22
|
-
* Redistribution and use in source and binary forms, with or without
|
23
|
-
* modification, are permitted provided that the following conditions
|
24
|
-
* are met:
|
25
|
-
* 1. Redistributions of source code must retain the copyright
|
26
|
-
* notice, this list of conditions and the following disclaimer.
|
27
|
-
* 2. Redistributions in binary form must reproduce the above copyright
|
28
|
-
* notice, this list of conditions and the following disclaimer in the
|
29
|
-
* documentation and/or other materials provided with the distribution.
|
30
|
-
* 3. All advertising materials mentioning features or use of this software
|
31
|
-
* must display the following acknowledgement:
|
32
|
-
* "This product includes cryptographic software written by
|
33
|
-
* Eric Young (eay@cryptsoft.com)"
|
34
|
-
* The word 'cryptographic' can be left out if the rouines from the library
|
35
|
-
* being used are not cryptographic related :-).
|
36
|
-
* 4. If you include any Windows specific code (or a derivative thereof) from
|
37
|
-
* the apps directory (application code) you must include an acknowledgement:
|
38
|
-
* "This product includes software written by Tim Hudson (tjh@cryptsoft.com)"
|
39
|
-
*
|
40
|
-
* THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND
|
41
|
-
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
42
|
-
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
43
|
-
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
44
|
-
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
45
|
-
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
46
|
-
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
47
|
-
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
48
|
-
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
49
|
-
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
50
|
-
* SUCH DAMAGE.
|
51
|
-
*
|
52
|
-
* The licence and distribution terms for any publically available version or
|
53
|
-
* derivative of this code cannot be changed. i.e. this code cannot simply be
|
54
|
-
* copied and put under another distribution licence
|
55
|
-
* [including the GNU Public Licence.] */
|
56
|
-
|
57
|
-
#include <openssl/asn1.h>
|
58
|
-
|
59
|
-
#include <openssl/bio.h>
|
60
|
-
#include <openssl/mem.h>
|
61
|
-
|
62
|
-
int ASN1_bn_print(BIO *bp, const char *number, const BIGNUM *num,
|
63
|
-
unsigned char *buf, int off)
|
64
|
-
{
|
65
|
-
int n, i;
|
66
|
-
const char *neg;
|
67
|
-
|
68
|
-
if (num == NULL)
|
69
|
-
return (1);
|
70
|
-
neg = (BN_is_negative(num)) ? "-" : "";
|
71
|
-
if (!BIO_indent(bp, off, 128))
|
72
|
-
return 0;
|
73
|
-
if (BN_is_zero(num)) {
|
74
|
-
if (BIO_printf(bp, "%s 0\n", number) <= 0)
|
75
|
-
return 0;
|
76
|
-
return 1;
|
77
|
-
}
|
78
|
-
|
79
|
-
if (BN_num_bytes(num) <= sizeof(long)) {
|
80
|
-
if (BIO_printf(bp, "%s %s%lu (%s0x%lx)\n", number, neg,
|
81
|
-
(unsigned long)num->d[0], neg,
|
82
|
-
(unsigned long)num->d[0])
|
83
|
-
<= 0)
|
84
|
-
return (0);
|
85
|
-
} else {
|
86
|
-
buf[0] = 0;
|
87
|
-
if (BIO_printf(bp, "%s%s", number,
|
88
|
-
(neg[0] == '-') ? " (Negative)" : "") <= 0)
|
89
|
-
return (0);
|
90
|
-
n = BN_bn2bin(num, &buf[1]);
|
91
|
-
|
92
|
-
if (buf[1] & 0x80)
|
93
|
-
n++;
|
94
|
-
else
|
95
|
-
buf++;
|
96
|
-
|
97
|
-
for (i = 0; i < n; i++) {
|
98
|
-
if ((i % 15) == 0) {
|
99
|
-
if (BIO_puts(bp, "\n") <= 0 || !BIO_indent(bp, off + 4, 128))
|
100
|
-
return 0;
|
101
|
-
}
|
102
|
-
if (BIO_printf(bp, "%02x%s", buf[i], ((i + 1) == n) ? "" : ":")
|
103
|
-
<= 0)
|
104
|
-
return (0);
|
105
|
-
}
|
106
|
-
if (BIO_write(bp, "\n", 1) <= 0)
|
107
|
-
return (0);
|
108
|
-
}
|
109
|
-
return (1);
|
110
|
-
}
|
@@ -1,596 +0,0 @@
|
|
1
|
-
/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
|
2
|
-
* All rights reserved.
|
3
|
-
*
|
4
|
-
* This package is an SSL implementation written
|
5
|
-
* by Eric Young (eay@cryptsoft.com).
|
6
|
-
* The implementation was written so as to conform with Netscapes SSL.
|
7
|
-
*
|
8
|
-
* This library is free for commercial and non-commercial use as long as
|
9
|
-
* the following conditions are aheared to. The following conditions
|
10
|
-
* apply to all code found in this distribution, be it the RC4, RSA,
|
11
|
-
* lhash, DES, etc., code; not just the SSL code. The SSL documentation
|
12
|
-
* included with this distribution is covered by the same copyright terms
|
13
|
-
* except that the holder is Tim Hudson (tjh@cryptsoft.com).
|
14
|
-
*
|
15
|
-
* Copyright remains Eric Young's, and as such any Copyright notices in
|
16
|
-
* the code are not to be removed.
|
17
|
-
* If this package is used in a product, Eric Young should be given attribution
|
18
|
-
* as the author of the parts of the library used.
|
19
|
-
* This can be in the form of a textual message at program startup or
|
20
|
-
* in documentation (online or textual) provided with the package.
|
21
|
-
*
|
22
|
-
* Redistribution and use in source and binary forms, with or without
|
23
|
-
* modification, are permitted provided that the following conditions
|
24
|
-
* are met:
|
25
|
-
* 1. Redistributions of source code must retain the copyright
|
26
|
-
* notice, this list of conditions and the following disclaimer.
|
27
|
-
* 2. Redistributions in binary form must reproduce the above copyright
|
28
|
-
* notice, this list of conditions and the following disclaimer in the
|
29
|
-
* documentation and/or other materials provided with the distribution.
|
30
|
-
* 3. All advertising materials mentioning features or use of this software
|
31
|
-
* must display the following acknowledgement:
|
32
|
-
* "This product includes cryptographic software written by
|
33
|
-
* Eric Young (eay@cryptsoft.com)"
|
34
|
-
* The word 'cryptographic' can be left out if the rouines from the library
|
35
|
-
* being used are not cryptographic related :-).
|
36
|
-
* 4. If you include any Windows specific code (or a derivative thereof) from
|
37
|
-
* the apps directory (application code) you must include an acknowledgement:
|
38
|
-
* "This product includes software written by Tim Hudson (tjh@cryptsoft.com)"
|
39
|
-
*
|
40
|
-
* THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND
|
41
|
-
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
42
|
-
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
43
|
-
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
44
|
-
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
45
|
-
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
46
|
-
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
47
|
-
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
48
|
-
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
49
|
-
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
50
|
-
* SUCH DAMAGE.
|
51
|
-
*
|
52
|
-
* The licence and distribution terms for any publically available version or
|
53
|
-
* derivative of this code cannot be changed. i.e. this code cannot simply be
|
54
|
-
* copied and put under another distribution licence
|
55
|
-
* [including the GNU Public Licence.] */
|
56
|
-
|
57
|
-
#include <openssl/asn1.h>
|
58
|
-
|
59
|
-
#include <time.h>
|
60
|
-
|
61
|
-
#include <openssl/asn1t.h>
|
62
|
-
#include <openssl/err.h>
|
63
|
-
#include <openssl/obj.h>
|
64
|
-
#include <openssl/mem.h>
|
65
|
-
|
66
|
-
#include "asn1_locl.h"
|
67
|
-
|
68
|
-
/*
|
69
|
-
* Print routines.
|
70
|
-
*/
|
71
|
-
|
72
|
-
/* ASN1_PCTX routines */
|
73
|
-
|
74
|
-
static ASN1_PCTX default_pctx = {
|
75
|
-
ASN1_PCTX_FLAGS_SHOW_ABSENT, /* flags */
|
76
|
-
0, /* nm_flags */
|
77
|
-
0, /* cert_flags */
|
78
|
-
0, /* oid_flags */
|
79
|
-
0 /* str_flags */
|
80
|
-
};
|
81
|
-
|
82
|
-
ASN1_PCTX *ASN1_PCTX_new(void)
|
83
|
-
{
|
84
|
-
ASN1_PCTX *ret;
|
85
|
-
ret = OPENSSL_malloc(sizeof(ASN1_PCTX));
|
86
|
-
if (ret == NULL) {
|
87
|
-
OPENSSL_PUT_ERROR(ASN1, ERR_R_MALLOC_FAILURE);
|
88
|
-
return NULL;
|
89
|
-
}
|
90
|
-
ret->flags = 0;
|
91
|
-
ret->nm_flags = 0;
|
92
|
-
ret->cert_flags = 0;
|
93
|
-
ret->oid_flags = 0;
|
94
|
-
ret->str_flags = 0;
|
95
|
-
return ret;
|
96
|
-
}
|
97
|
-
|
98
|
-
void ASN1_PCTX_free(ASN1_PCTX *p)
|
99
|
-
{
|
100
|
-
OPENSSL_free(p);
|
101
|
-
}
|
102
|
-
|
103
|
-
unsigned long ASN1_PCTX_get_flags(ASN1_PCTX *p)
|
104
|
-
{
|
105
|
-
return p->flags;
|
106
|
-
}
|
107
|
-
|
108
|
-
void ASN1_PCTX_set_flags(ASN1_PCTX *p, unsigned long flags)
|
109
|
-
{
|
110
|
-
p->flags = flags;
|
111
|
-
}
|
112
|
-
|
113
|
-
unsigned long ASN1_PCTX_get_nm_flags(ASN1_PCTX *p)
|
114
|
-
{
|
115
|
-
return p->nm_flags;
|
116
|
-
}
|
117
|
-
|
118
|
-
void ASN1_PCTX_set_nm_flags(ASN1_PCTX *p, unsigned long flags)
|
119
|
-
{
|
120
|
-
p->nm_flags = flags;
|
121
|
-
}
|
122
|
-
|
123
|
-
unsigned long ASN1_PCTX_get_cert_flags(ASN1_PCTX *p)
|
124
|
-
{
|
125
|
-
return p->cert_flags;
|
126
|
-
}
|
127
|
-
|
128
|
-
void ASN1_PCTX_set_cert_flags(ASN1_PCTX *p, unsigned long flags)
|
129
|
-
{
|
130
|
-
p->cert_flags = flags;
|
131
|
-
}
|
132
|
-
|
133
|
-
unsigned long ASN1_PCTX_get_oid_flags(ASN1_PCTX *p)
|
134
|
-
{
|
135
|
-
return p->oid_flags;
|
136
|
-
}
|
137
|
-
|
138
|
-
void ASN1_PCTX_set_oid_flags(ASN1_PCTX *p, unsigned long flags)
|
139
|
-
{
|
140
|
-
p->oid_flags = flags;
|
141
|
-
}
|
142
|
-
|
143
|
-
unsigned long ASN1_PCTX_get_str_flags(ASN1_PCTX *p)
|
144
|
-
{
|
145
|
-
return p->str_flags;
|
146
|
-
}
|
147
|
-
|
148
|
-
void ASN1_PCTX_set_str_flags(ASN1_PCTX *p, unsigned long flags)
|
149
|
-
{
|
150
|
-
p->str_flags = flags;
|
151
|
-
}
|
152
|
-
|
153
|
-
/* Main print routines */
|
154
|
-
|
155
|
-
static int asn1_item_print_ctx(BIO *out, ASN1_VALUE **fld, int indent,
|
156
|
-
const ASN1_ITEM *it,
|
157
|
-
const char *fname, const char *sname,
|
158
|
-
int nohdr, const ASN1_PCTX *pctx);
|
159
|
-
|
160
|
-
int asn1_template_print_ctx(BIO *out, ASN1_VALUE **fld, int indent,
|
161
|
-
const ASN1_TEMPLATE *tt, const ASN1_PCTX *pctx);
|
162
|
-
|
163
|
-
static int asn1_primitive_print(BIO *out, ASN1_VALUE **fld,
|
164
|
-
const ASN1_ITEM *it, int indent,
|
165
|
-
const char *fname, const char *sname,
|
166
|
-
const ASN1_PCTX *pctx);
|
167
|
-
|
168
|
-
static int asn1_print_fsname(BIO *out, int indent,
|
169
|
-
const char *fname, const char *sname,
|
170
|
-
const ASN1_PCTX *pctx);
|
171
|
-
|
172
|
-
int ASN1_item_print(BIO *out, ASN1_VALUE *ifld, int indent,
|
173
|
-
const ASN1_ITEM *it, const ASN1_PCTX *pctx)
|
174
|
-
{
|
175
|
-
const char *sname;
|
176
|
-
if (pctx == NULL)
|
177
|
-
pctx = &default_pctx;
|
178
|
-
if (pctx->flags & ASN1_PCTX_FLAGS_NO_STRUCT_NAME)
|
179
|
-
sname = NULL;
|
180
|
-
else
|
181
|
-
sname = it->sname;
|
182
|
-
return asn1_item_print_ctx(out, &ifld, indent, it, NULL, sname, 0, pctx);
|
183
|
-
}
|
184
|
-
|
185
|
-
static int asn1_item_print_ctx(BIO *out, ASN1_VALUE **fld, int indent,
|
186
|
-
const ASN1_ITEM *it,
|
187
|
-
const char *fname, const char *sname,
|
188
|
-
int nohdr, const ASN1_PCTX *pctx)
|
189
|
-
{
|
190
|
-
const ASN1_TEMPLATE *tt;
|
191
|
-
const ASN1_EXTERN_FUNCS *ef;
|
192
|
-
ASN1_VALUE **tmpfld;
|
193
|
-
const ASN1_AUX *aux = it->funcs;
|
194
|
-
ASN1_aux_cb *asn1_cb;
|
195
|
-
ASN1_PRINT_ARG parg;
|
196
|
-
int i;
|
197
|
-
if (aux && aux->asn1_cb) {
|
198
|
-
parg.out = out;
|
199
|
-
parg.indent = indent;
|
200
|
-
parg.pctx = pctx;
|
201
|
-
asn1_cb = aux->asn1_cb;
|
202
|
-
} else
|
203
|
-
asn1_cb = 0;
|
204
|
-
|
205
|
-
if (*fld == NULL) {
|
206
|
-
if (pctx->flags & ASN1_PCTX_FLAGS_SHOW_ABSENT) {
|
207
|
-
if (!nohdr && !asn1_print_fsname(out, indent, fname, sname, pctx))
|
208
|
-
return 0;
|
209
|
-
if (BIO_puts(out, "<ABSENT>\n") <= 0)
|
210
|
-
return 0;
|
211
|
-
}
|
212
|
-
return 1;
|
213
|
-
}
|
214
|
-
|
215
|
-
switch (it->itype) {
|
216
|
-
case ASN1_ITYPE_PRIMITIVE:
|
217
|
-
if (it->templates) {
|
218
|
-
if (!asn1_template_print_ctx(out, fld, indent,
|
219
|
-
it->templates, pctx))
|
220
|
-
return 0;
|
221
|
-
break;
|
222
|
-
}
|
223
|
-
/* fall thru */
|
224
|
-
case ASN1_ITYPE_MSTRING:
|
225
|
-
if (!asn1_primitive_print(out, fld, it, indent, fname, sname, pctx))
|
226
|
-
return 0;
|
227
|
-
break;
|
228
|
-
|
229
|
-
case ASN1_ITYPE_EXTERN:
|
230
|
-
if (!nohdr && !asn1_print_fsname(out, indent, fname, sname, pctx))
|
231
|
-
return 0;
|
232
|
-
/* Use new style print routine if possible */
|
233
|
-
ef = it->funcs;
|
234
|
-
if (ef && ef->asn1_ex_print) {
|
235
|
-
i = ef->asn1_ex_print(out, fld, indent, "", pctx);
|
236
|
-
if (!i)
|
237
|
-
return 0;
|
238
|
-
if ((i == 2) && (BIO_puts(out, "\n") <= 0))
|
239
|
-
return 0;
|
240
|
-
return 1;
|
241
|
-
} else if (sname &&
|
242
|
-
BIO_printf(out, ":EXTERNAL TYPE %s\n", sname) <= 0)
|
243
|
-
return 0;
|
244
|
-
break;
|
245
|
-
|
246
|
-
case ASN1_ITYPE_CHOICE:
|
247
|
-
#if 0
|
248
|
-
if (!nohdr && !asn1_print_fsname(out, indent, fname, sname, pctx))
|
249
|
-
return 0;
|
250
|
-
#endif
|
251
|
-
/* CHOICE type, get selector */
|
252
|
-
i = asn1_get_choice_selector(fld, it);
|
253
|
-
/* This should never happen... */
|
254
|
-
if ((i < 0) || (i >= it->tcount)) {
|
255
|
-
if (BIO_printf(out, "ERROR: selector [%d] invalid\n", i) <= 0)
|
256
|
-
return 0;
|
257
|
-
return 1;
|
258
|
-
}
|
259
|
-
tt = it->templates + i;
|
260
|
-
tmpfld = asn1_get_field_ptr(fld, tt);
|
261
|
-
if (!asn1_template_print_ctx(out, tmpfld, indent, tt, pctx))
|
262
|
-
return 0;
|
263
|
-
break;
|
264
|
-
|
265
|
-
case ASN1_ITYPE_SEQUENCE:
|
266
|
-
case ASN1_ITYPE_NDEF_SEQUENCE:
|
267
|
-
if (!nohdr && !asn1_print_fsname(out, indent, fname, sname, pctx))
|
268
|
-
return 0;
|
269
|
-
if (fname || sname) {
|
270
|
-
if (pctx->flags & ASN1_PCTX_FLAGS_SHOW_SEQUENCE) {
|
271
|
-
if (BIO_puts(out, " {\n") <= 0)
|
272
|
-
return 0;
|
273
|
-
} else {
|
274
|
-
if (BIO_puts(out, "\n") <= 0)
|
275
|
-
return 0;
|
276
|
-
}
|
277
|
-
}
|
278
|
-
|
279
|
-
if (asn1_cb) {
|
280
|
-
i = asn1_cb(ASN1_OP_PRINT_PRE, fld, it, &parg);
|
281
|
-
if (i == 0)
|
282
|
-
return 0;
|
283
|
-
if (i == 2)
|
284
|
-
return 1;
|
285
|
-
}
|
286
|
-
|
287
|
-
/* Print each field entry */
|
288
|
-
for (i = 0, tt = it->templates; i < it->tcount; i++, tt++) {
|
289
|
-
const ASN1_TEMPLATE *seqtt;
|
290
|
-
seqtt = asn1_do_adb(fld, tt, 1);
|
291
|
-
if (!seqtt)
|
292
|
-
return 0;
|
293
|
-
tmpfld = asn1_get_field_ptr(fld, seqtt);
|
294
|
-
if (!asn1_template_print_ctx(out, tmpfld,
|
295
|
-
indent + 2, seqtt, pctx))
|
296
|
-
return 0;
|
297
|
-
}
|
298
|
-
if (pctx->flags & ASN1_PCTX_FLAGS_SHOW_SEQUENCE) {
|
299
|
-
if (BIO_printf(out, "%*s}\n", indent, "") < 0)
|
300
|
-
return 0;
|
301
|
-
}
|
302
|
-
|
303
|
-
if (asn1_cb) {
|
304
|
-
i = asn1_cb(ASN1_OP_PRINT_POST, fld, it, &parg);
|
305
|
-
if (i == 0)
|
306
|
-
return 0;
|
307
|
-
}
|
308
|
-
break;
|
309
|
-
|
310
|
-
default:
|
311
|
-
BIO_printf(out, "Unprocessed type %d\n", it->itype);
|
312
|
-
return 0;
|
313
|
-
}
|
314
|
-
|
315
|
-
return 1;
|
316
|
-
}
|
317
|
-
|
318
|
-
int asn1_template_print_ctx(BIO *out, ASN1_VALUE **fld, int indent,
|
319
|
-
const ASN1_TEMPLATE *tt, const ASN1_PCTX *pctx)
|
320
|
-
{
|
321
|
-
int flags;
|
322
|
-
size_t i;
|
323
|
-
const char *sname, *fname;
|
324
|
-
flags = tt->flags;
|
325
|
-
if (pctx->flags & ASN1_PCTX_FLAGS_SHOW_FIELD_STRUCT_NAME)
|
326
|
-
sname = ASN1_ITEM_ptr(tt->item)->sname;
|
327
|
-
else
|
328
|
-
sname = NULL;
|
329
|
-
if (pctx->flags & ASN1_PCTX_FLAGS_NO_FIELD_NAME)
|
330
|
-
fname = NULL;
|
331
|
-
else
|
332
|
-
fname = tt->field_name;
|
333
|
-
if (flags & ASN1_TFLG_SK_MASK) {
|
334
|
-
const char *tname;
|
335
|
-
ASN1_VALUE *skitem;
|
336
|
-
STACK_OF(ASN1_VALUE) *stack;
|
337
|
-
|
338
|
-
/* SET OF, SEQUENCE OF */
|
339
|
-
if (fname) {
|
340
|
-
if (pctx->flags & ASN1_PCTX_FLAGS_SHOW_SSOF) {
|
341
|
-
if (flags & ASN1_TFLG_SET_OF)
|
342
|
-
tname = "SET";
|
343
|
-
else
|
344
|
-
tname = "SEQUENCE";
|
345
|
-
if (BIO_printf(out, "%*s%s OF %s {\n",
|
346
|
-
indent, "", tname, tt->field_name) <= 0)
|
347
|
-
return 0;
|
348
|
-
} else if (BIO_printf(out, "%*s%s:\n", indent, "", fname) <= 0)
|
349
|
-
return 0;
|
350
|
-
}
|
351
|
-
stack = (STACK_OF(ASN1_VALUE) *)*fld;
|
352
|
-
for (i = 0; i < sk_ASN1_VALUE_num(stack); i++) {
|
353
|
-
if ((i > 0) && (BIO_puts(out, "\n") <= 0))
|
354
|
-
return 0;
|
355
|
-
|
356
|
-
skitem = sk_ASN1_VALUE_value(stack, i);
|
357
|
-
if (!asn1_item_print_ctx(out, &skitem, indent + 2,
|
358
|
-
ASN1_ITEM_ptr(tt->item), NULL, NULL, 1,
|
359
|
-
pctx))
|
360
|
-
return 0;
|
361
|
-
}
|
362
|
-
if (!i && BIO_printf(out, "%*s<EMPTY>\n", indent + 2, "") <= 0)
|
363
|
-
return 0;
|
364
|
-
if (pctx->flags & ASN1_PCTX_FLAGS_SHOW_SEQUENCE) {
|
365
|
-
if (BIO_printf(out, "%*s}\n", indent, "") <= 0)
|
366
|
-
return 0;
|
367
|
-
}
|
368
|
-
return 1;
|
369
|
-
}
|
370
|
-
return asn1_item_print_ctx(out, fld, indent, ASN1_ITEM_ptr(tt->item),
|
371
|
-
fname, sname, 0, pctx);
|
372
|
-
}
|
373
|
-
|
374
|
-
static int asn1_print_fsname(BIO *out, int indent,
|
375
|
-
const char *fname, const char *sname,
|
376
|
-
const ASN1_PCTX *pctx)
|
377
|
-
{
|
378
|
-
static char spaces[] = " ";
|
379
|
-
const int nspaces = sizeof(spaces) - 1;
|
380
|
-
|
381
|
-
#if 0
|
382
|
-
if (!sname && !fname)
|
383
|
-
return 1;
|
384
|
-
#endif
|
385
|
-
|
386
|
-
while (indent > nspaces) {
|
387
|
-
if (BIO_write(out, spaces, nspaces) != nspaces)
|
388
|
-
return 0;
|
389
|
-
indent -= nspaces;
|
390
|
-
}
|
391
|
-
if (BIO_write(out, spaces, indent) != indent)
|
392
|
-
return 0;
|
393
|
-
if (pctx->flags & ASN1_PCTX_FLAGS_NO_STRUCT_NAME)
|
394
|
-
sname = NULL;
|
395
|
-
if (pctx->flags & ASN1_PCTX_FLAGS_NO_FIELD_NAME)
|
396
|
-
fname = NULL;
|
397
|
-
if (!sname && !fname)
|
398
|
-
return 1;
|
399
|
-
if (fname) {
|
400
|
-
if (BIO_puts(out, fname) <= 0)
|
401
|
-
return 0;
|
402
|
-
}
|
403
|
-
if (sname) {
|
404
|
-
if (fname) {
|
405
|
-
if (BIO_printf(out, " (%s)", sname) <= 0)
|
406
|
-
return 0;
|
407
|
-
} else {
|
408
|
-
if (BIO_puts(out, sname) <= 0)
|
409
|
-
return 0;
|
410
|
-
}
|
411
|
-
}
|
412
|
-
if (BIO_write(out, ": ", 2) != 2)
|
413
|
-
return 0;
|
414
|
-
return 1;
|
415
|
-
}
|
416
|
-
|
417
|
-
static int asn1_print_boolean_ctx(BIO *out, int boolval,
|
418
|
-
const ASN1_PCTX *pctx)
|
419
|
-
{
|
420
|
-
const char *str;
|
421
|
-
switch (boolval) {
|
422
|
-
case -1:
|
423
|
-
str = "BOOL ABSENT";
|
424
|
-
break;
|
425
|
-
|
426
|
-
case 0:
|
427
|
-
str = "FALSE";
|
428
|
-
break;
|
429
|
-
|
430
|
-
default:
|
431
|
-
str = "TRUE";
|
432
|
-
break;
|
433
|
-
|
434
|
-
}
|
435
|
-
|
436
|
-
if (BIO_puts(out, str) <= 0)
|
437
|
-
return 0;
|
438
|
-
return 1;
|
439
|
-
|
440
|
-
}
|
441
|
-
|
442
|
-
static int asn1_print_integer_ctx(BIO *out, ASN1_INTEGER *str,
|
443
|
-
const ASN1_PCTX *pctx)
|
444
|
-
{
|
445
|
-
BIGNUM *bn = NULL;
|
446
|
-
char *s = NULL;
|
447
|
-
int ret = 1;
|
448
|
-
|
449
|
-
bn = ASN1_INTEGER_to_BN(str, NULL);
|
450
|
-
if (bn == NULL) {
|
451
|
-
return 0;
|
452
|
-
}
|
453
|
-
s = BN_bn2dec(bn);
|
454
|
-
BN_free(bn);
|
455
|
-
if (s == NULL) {
|
456
|
-
return 0;
|
457
|
-
}
|
458
|
-
|
459
|
-
if (BIO_puts(out, s) <= 0) {
|
460
|
-
ret = 0;
|
461
|
-
}
|
462
|
-
OPENSSL_free(s);
|
463
|
-
return ret;
|
464
|
-
}
|
465
|
-
|
466
|
-
static int asn1_print_oid_ctx(BIO *out, const ASN1_OBJECT *oid,
|
467
|
-
const ASN1_PCTX *pctx)
|
468
|
-
{
|
469
|
-
char objbuf[80];
|
470
|
-
const char *ln;
|
471
|
-
ln = OBJ_nid2ln(OBJ_obj2nid(oid));
|
472
|
-
if (!ln)
|
473
|
-
ln = "";
|
474
|
-
OBJ_obj2txt(objbuf, sizeof objbuf, oid, 1);
|
475
|
-
if (BIO_printf(out, "%s (%s)", ln, objbuf) <= 0)
|
476
|
-
return 0;
|
477
|
-
return 1;
|
478
|
-
}
|
479
|
-
|
480
|
-
static int asn1_print_obstring_ctx(BIO *out, ASN1_STRING *str, int indent,
|
481
|
-
const ASN1_PCTX *pctx)
|
482
|
-
{
|
483
|
-
if (str->type == V_ASN1_BIT_STRING) {
|
484
|
-
if (BIO_printf(out, " (%ld unused bits)\n", str->flags & 0x7) <= 0)
|
485
|
-
return 0;
|
486
|
-
} else if (BIO_puts(out, "\n") <= 0)
|
487
|
-
return 0;
|
488
|
-
if (str->length > 0
|
489
|
-
&& !BIO_hexdump(out, str->data, str->length, indent + 2)) {
|
490
|
-
return 0;
|
491
|
-
}
|
492
|
-
return 1;
|
493
|
-
}
|
494
|
-
|
495
|
-
static int asn1_primitive_print(BIO *out, ASN1_VALUE **fld,
|
496
|
-
const ASN1_ITEM *it, int indent,
|
497
|
-
const char *fname, const char *sname,
|
498
|
-
const ASN1_PCTX *pctx)
|
499
|
-
{
|
500
|
-
long utype;
|
501
|
-
ASN1_STRING *str;
|
502
|
-
int ret = 1, needlf = 1;
|
503
|
-
const char *pname;
|
504
|
-
const ASN1_PRIMITIVE_FUNCS *pf;
|
505
|
-
pf = it->funcs;
|
506
|
-
if (!asn1_print_fsname(out, indent, fname, sname, pctx))
|
507
|
-
return 0;
|
508
|
-
if (pf && pf->prim_print)
|
509
|
-
return pf->prim_print(out, fld, it, indent, pctx);
|
510
|
-
str = (ASN1_STRING *)*fld;
|
511
|
-
if (it->itype == ASN1_ITYPE_MSTRING)
|
512
|
-
utype = str->type & ~V_ASN1_NEG;
|
513
|
-
else
|
514
|
-
utype = it->utype;
|
515
|
-
if (utype == V_ASN1_ANY) {
|
516
|
-
ASN1_TYPE *atype = (ASN1_TYPE *)*fld;
|
517
|
-
utype = atype->type;
|
518
|
-
fld = &atype->value.asn1_value;
|
519
|
-
str = (ASN1_STRING *)*fld;
|
520
|
-
if (pctx->flags & ASN1_PCTX_FLAGS_NO_ANY_TYPE)
|
521
|
-
pname = NULL;
|
522
|
-
else
|
523
|
-
pname = ASN1_tag2str(utype);
|
524
|
-
} else {
|
525
|
-
if (pctx->flags & ASN1_PCTX_FLAGS_SHOW_TYPE)
|
526
|
-
pname = ASN1_tag2str(utype);
|
527
|
-
else
|
528
|
-
pname = NULL;
|
529
|
-
}
|
530
|
-
|
531
|
-
if (utype == V_ASN1_NULL) {
|
532
|
-
if (BIO_puts(out, "NULL\n") <= 0)
|
533
|
-
return 0;
|
534
|
-
return 1;
|
535
|
-
}
|
536
|
-
|
537
|
-
if (pname) {
|
538
|
-
if (BIO_puts(out, pname) <= 0)
|
539
|
-
return 0;
|
540
|
-
if (BIO_puts(out, ":") <= 0)
|
541
|
-
return 0;
|
542
|
-
}
|
543
|
-
|
544
|
-
switch (utype) {
|
545
|
-
case V_ASN1_BOOLEAN:
|
546
|
-
{
|
547
|
-
int boolval = *(int *)fld;
|
548
|
-
if (boolval == -1)
|
549
|
-
boolval = it->size;
|
550
|
-
ret = asn1_print_boolean_ctx(out, boolval, pctx);
|
551
|
-
}
|
552
|
-
break;
|
553
|
-
|
554
|
-
case V_ASN1_INTEGER:
|
555
|
-
case V_ASN1_ENUMERATED:
|
556
|
-
ret = asn1_print_integer_ctx(out, str, pctx);
|
557
|
-
break;
|
558
|
-
|
559
|
-
case V_ASN1_UTCTIME:
|
560
|
-
ret = ASN1_UTCTIME_print(out, str);
|
561
|
-
break;
|
562
|
-
|
563
|
-
case V_ASN1_GENERALIZEDTIME:
|
564
|
-
ret = ASN1_GENERALIZEDTIME_print(out, str);
|
565
|
-
break;
|
566
|
-
|
567
|
-
case V_ASN1_OBJECT:
|
568
|
-
ret = asn1_print_oid_ctx(out, (const ASN1_OBJECT *)*fld, pctx);
|
569
|
-
break;
|
570
|
-
|
571
|
-
case V_ASN1_OCTET_STRING:
|
572
|
-
case V_ASN1_BIT_STRING:
|
573
|
-
ret = asn1_print_obstring_ctx(out, str, indent, pctx);
|
574
|
-
needlf = 0;
|
575
|
-
break;
|
576
|
-
|
577
|
-
case V_ASN1_SEQUENCE:
|
578
|
-
case V_ASN1_SET:
|
579
|
-
case V_ASN1_OTHER:
|
580
|
-
if (BIO_puts(out, "\n") <= 0)
|
581
|
-
return 0;
|
582
|
-
if (ASN1_parse_dump(out, str->data, str->length, indent, 0) <= 0)
|
583
|
-
ret = 0;
|
584
|
-
needlf = 0;
|
585
|
-
break;
|
586
|
-
|
587
|
-
default:
|
588
|
-
ret = ASN1_STRING_print_ex(out, str, pctx->str_flags);
|
589
|
-
|
590
|
-
}
|
591
|
-
if (!ret)
|
592
|
-
return 0;
|
593
|
-
if (needlf && BIO_puts(out, "\n") <= 0)
|
594
|
-
return 0;
|
595
|
-
return 1;
|
596
|
-
}
|