grpc 0.12.0 → 0.13.0.pre1.1
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 +5707 -22222
- data/include/grpc/byte_buffer.h +2 -83
- data/include/grpc/census.h +191 -121
- data/include/grpc/compression.h +14 -38
- data/include/grpc/grpc.h +88 -434
- data/include/grpc/grpc_security.h +76 -46
- data/include/grpc/grpc_zookeeper.h +1 -1
- data/include/grpc/impl/codegen/alloc.h +74 -0
- data/include/grpc/impl/codegen/atm.h +92 -0
- data/include/grpc/impl/codegen/atm_gcc_atomic.h +72 -0
- data/include/grpc/impl/codegen/atm_gcc_sync.h +87 -0
- data/include/grpc/impl/codegen/atm_win32.h +125 -0
- data/include/grpc/impl/codegen/byte_buffer.h +121 -0
- data/include/grpc/impl/codegen/compression_types.h +73 -0
- data/include/grpc/impl/codegen/connectivity_state.h +59 -0
- data/include/grpc/impl/codegen/grpc_types.h +373 -0
- data/include/grpc/impl/codegen/log.h +110 -0
- data/include/grpc/impl/codegen/port_platform.h +362 -0
- data/include/grpc/impl/codegen/propagation_bits.h +67 -0
- data/include/grpc/impl/codegen/slice.h +182 -0
- data/include/grpc/impl/codegen/slice_buffer.h +105 -0
- data/include/grpc/impl/codegen/status.h +163 -0
- data/include/grpc/impl/codegen/sync.h +316 -0
- data/include/grpc/impl/codegen/sync_generic.h +55 -0
- data/{src/core/census/context.h → include/grpc/impl/codegen/sync_posix.h} +11 -11
- data/include/grpc/impl/codegen/sync_win32.h +49 -0
- data/include/grpc/impl/codegen/time.h +132 -0
- data/include/grpc/status.h +2 -126
- data/include/grpc/support/alloc.h +2 -35
- data/include/grpc/support/atm.h +2 -55
- data/include/grpc/support/atm_gcc_atomic.h +5 -38
- data/include/grpc/support/atm_gcc_sync.h +2 -50
- data/include/grpc/support/atm_win32.h +2 -88
- data/include/grpc/support/avl.h +7 -7
- data/include/grpc/support/cmdline.h +15 -13
- data/include/grpc/support/cpu.h +5 -3
- data/include/grpc/support/histogram.h +23 -20
- data/include/grpc/support/host_port.h +5 -3
- data/include/grpc/support/log.h +2 -71
- data/include/grpc/support/log_win32.h +2 -2
- data/include/grpc/support/port_platform.h +2 -319
- data/include/grpc/support/slice.h +2 -145
- data/include/grpc/support/slice_buffer.h +2 -65
- data/include/grpc/support/string_util.h +3 -3
- data/include/grpc/support/subprocess.h +8 -6
- data/include/grpc/support/sync.h +2 -278
- data/include/grpc/support/sync_generic.h +2 -18
- data/include/grpc/support/sync_posix.h +2 -10
- data/include/grpc/support/sync_win32.h +2 -12
- data/include/grpc/support/thd.h +11 -11
- data/include/grpc/support/time.h +2 -91
- data/include/grpc/support/tls.h +1 -1
- data/include/grpc/support/tls_gcc.h +1 -1
- data/include/grpc/support/tls_msvc.h +1 -1
- data/include/grpc/support/tls_pthread.h +2 -2
- data/src/boringssl/err_data.c +1252 -0
- data/src/core/census/context.c +492 -8
- data/src/core/census/grpc_filter.c +3 -3
- data/src/core/census/initialize.c +4 -7
- data/src/core/census/operation.c +2 -2
- data/src/core/census/placeholders.c +109 -0
- data/src/core/census/rpc_metric_id.h +6 -6
- data/src/core/census/tracing.c +1 -1
- data/src/core/channel/channel_args.c +4 -3
- data/src/core/channel/channel_stack.c +1 -1
- data/src/core/channel/client_channel.c +18 -14
- data/src/core/channel/client_uchannel.c +3 -3
- data/src/core/channel/compress_filter.c +8 -8
- data/src/core/channel/http_client_filter.c +2 -2
- data/src/core/channel/http_server_filter.c +9 -9
- data/src/core/channel/subchannel_call_holder.c +12 -10
- data/src/core/client_config/lb_policies/pick_first.c +49 -31
- data/src/core/client_config/lb_policies/round_robin.c +7 -7
- data/src/core/client_config/resolvers/dns_resolver.c +3 -3
- data/src/core/client_config/resolvers/sockaddr_resolver.c +5 -5
- data/src/core/client_config/subchannel.c +36 -25
- data/src/core/compression/algorithm.c +3 -3
- data/src/core/httpcli/format_request.c +1 -1
- data/src/core/httpcli/httpcli.c +5 -5
- data/src/core/httpcli/httpcli_security_connector.c +2 -3
- data/src/core/httpcli/parser.c +7 -7
- data/src/core/httpcli/parser.h +1 -1
- data/src/core/iomgr/closure.c +7 -7
- data/src/core/iomgr/closure.h +6 -5
- data/src/core/iomgr/exec_ctx.c +12 -8
- data/src/core/iomgr/exec_ctx.h +12 -5
- data/src/core/iomgr/executor.c +4 -4
- data/src/core/iomgr/executor.h +2 -2
- data/src/core/iomgr/fd_posix.c +28 -17
- data/src/core/iomgr/fd_posix.h +7 -4
- data/src/core/iomgr/iocp_windows.c +6 -8
- data/src/core/iomgr/pollset_multipoller_with_epoll.c +70 -5
- data/src/core/iomgr/pollset_multipoller_with_poll_posix.c +4 -2
- data/src/core/iomgr/pollset_posix.c +15 -15
- data/src/core/iomgr/pollset_posix.h +4 -2
- data/src/core/iomgr/pollset_windows.c +3 -12
- data/src/core/iomgr/resolve_address_posix.c +2 -2
- data/src/core/iomgr/resolve_address_windows.c +2 -2
- data/src/core/iomgr/sockaddr_utils.c +6 -6
- data/src/core/iomgr/sockaddr_win32.h +1 -6
- data/src/core/iomgr/tcp_client_posix.c +7 -7
- data/src/core/iomgr/tcp_client_windows.c +4 -4
- data/src/core/iomgr/tcp_posix.c +14 -8
- data/src/core/iomgr/tcp_posix.h +7 -1
- data/src/core/iomgr/tcp_server.h +40 -20
- data/src/core/iomgr/tcp_server_posix.c +106 -49
- data/src/core/iomgr/tcp_server_windows.c +98 -49
- data/src/core/iomgr/tcp_windows.c +11 -15
- data/src/core/iomgr/timer.c +8 -8
- data/src/core/iomgr/timer.h +1 -1
- data/src/core/iomgr/timer_heap.c +10 -10
- data/src/core/iomgr/timer_heap.h +2 -2
- data/src/core/iomgr/udp_server.c +2 -12
- data/src/core/iomgr/udp_server.h +1 -9
- data/src/core/iomgr/workqueue.h +2 -4
- data/src/core/iomgr/workqueue_posix.c +3 -3
- data/src/core/json/json_reader.c +11 -12
- data/src/core/json/json_reader.h +4 -4
- data/src/core/json/json_string.c +19 -19
- data/src/core/json/json_writer.c +7 -9
- data/src/core/profiling/basic_timers.c +1 -1
- data/src/core/security/base64.c +9 -9
- data/src/core/security/client_auth_filter.c +4 -4
- data/src/core/security/credentials.c +5 -5
- data/src/core/security/google_default_credentials.c +3 -3
- data/src/core/security/handshake.c +6 -5
- data/src/core/security/json_token.c +13 -7
- data/src/core/security/jwt_verifier.c +3 -2
- data/src/core/security/secure_endpoint.c +16 -16
- data/src/core/security/security_connector.c +47 -17
- data/src/core/security/security_connector.h +5 -5
- data/src/core/security/server_auth_filter.c +3 -3
- data/src/core/security/server_secure_chttp2.c +30 -31
- data/src/core/statistics/census_interface.h +2 -2
- data/src/core/statistics/census_rpc_stats.h +3 -3
- data/src/core/support/alloc.c +1 -1
- data/src/core/support/cpu_posix.c +2 -2
- data/src/core/support/env_linux.c +12 -2
- data/src/core/support/env_win32.c +15 -7
- data/src/core/support/histogram.c +5 -5
- data/src/core/support/log_posix.c +1 -1
- data/src/core/support/log_win32.c +4 -3
- data/src/core/support/murmur_hash.c +11 -11
- data/src/core/support/murmur_hash.h +1 -1
- data/src/core/support/slice.c +11 -11
- data/src/core/support/slice_buffer.c +6 -6
- data/src/core/support/stack_lockfree.c +20 -10
- data/src/core/support/string.c +15 -15
- data/src/core/support/string.h +5 -5
- data/src/core/support/string_win32.c +5 -5
- data/src/core/support/subprocess_windows.c +141 -0
- data/src/core/support/sync.c +4 -4
- data/src/core/support/sync_posix.c +2 -2
- data/src/core/support/sync_win32.c +10 -5
- data/src/core/support/time.c +29 -29
- data/src/core/support/time_posix.c +15 -6
- data/src/core/support/time_precise.c +2 -2
- data/src/core/support/time_win32.c +18 -9
- data/src/core/support/tls_pthread.c +1 -1
- data/src/core/support/wrap_memcpy.c +53 -0
- data/src/core/surface/alarm.c +83 -0
- data/src/core/surface/byte_buffer_reader.c +1 -1
- data/src/core/surface/call.c +78 -69
- data/src/core/surface/call.h +2 -2
- data/src/core/surface/call_test_only.h +2 -2
- data/src/core/surface/channel.c +9 -9
- data/src/core/surface/channel.h +1 -1
- data/src/core/surface/channel_connectivity.c +3 -3
- data/src/core/surface/channel_create.c +3 -3
- data/src/core/surface/channel_ping.c +2 -2
- data/src/core/surface/completion_queue.c +11 -12
- data/src/core/surface/completion_queue.h +1 -1
- data/src/core/surface/init.c +7 -5
- data/src/core/surface/lame_client.c +3 -3
- data/src/core/surface/secure_channel_create.c +3 -3
- data/src/core/surface/server.c +28 -28
- data/src/core/surface/server_chttp2.c +8 -8
- data/src/core/surface/server_create.c +1 -4
- data/src/core/surface/validate_metadata.c +3 -3
- data/src/core/surface/version.c +2 -2
- data/src/core/transport/byte_stream.c +8 -6
- data/src/core/transport/byte_stream.h +6 -5
- data/src/core/transport/chttp2/bin_encoder.c +29 -29
- data/src/core/transport/chttp2/frame_data.c +29 -26
- data/src/core/transport/chttp2/frame_data.h +6 -6
- data/src/core/transport/chttp2/frame_goaway.c +30 -30
- data/src/core/transport/chttp2/frame_goaway.h +6 -6
- data/src/core/transport/chttp2/frame_ping.c +6 -6
- data/src/core/transport/chttp2/frame_ping.h +5 -5
- data/src/core/transport/chttp2/frame_rst_stream.c +18 -19
- data/src/core/transport/chttp2/frame_rst_stream.h +4 -4
- data/src/core/transport/chttp2/frame_settings.c +30 -30
- data/src/core/transport/chttp2/frame_settings.h +13 -13
- data/src/core/transport/chttp2/frame_window_update.c +17 -18
- data/src/core/transport/chttp2/frame_window_update.h +5 -7
- data/src/core/transport/chttp2/hpack_encoder.c +69 -73
- data/src/core/transport/chttp2/hpack_encoder.h +16 -16
- data/src/core/transport/chttp2/hpack_parser.c +167 -167
- data/src/core/transport/chttp2/hpack_parser.h +16 -16
- data/src/core/transport/chttp2/hpack_table.c +13 -13
- data/src/core/transport/chttp2/hpack_table.h +11 -11
- data/src/core/transport/chttp2/internal.h +97 -86
- data/src/core/transport/chttp2/parsing.c +25 -25
- data/src/core/transport/chttp2/stream_lists.c +26 -3
- data/src/core/transport/chttp2/stream_map.c +13 -14
- data/src/core/transport/chttp2/stream_map.h +6 -7
- data/src/core/transport/chttp2/timeout_encoding.c +19 -16
- data/src/core/transport/chttp2/varint.c +8 -9
- data/src/core/transport/chttp2/varint.h +7 -8
- data/src/core/transport/chttp2/writing.c +26 -23
- data/src/core/transport/chttp2_transport.c +133 -92
- data/src/core/transport/connectivity_state.c +6 -6
- data/src/core/transport/metadata.c +18 -18
- data/src/core/transport/metadata.h +5 -5
- data/src/core/transport/static_metadata.c +15 -16
- data/src/core/transport/static_metadata.h +5 -5
- data/src/core/transport/transport.c +5 -5
- data/src/core/transport/transport.h +14 -1
- data/src/core/tsi/fake_transport_security.c +7 -7
- data/src/core/tsi/ssl_transport_security.c +6 -4
- data/src/core/tsi/ssl_types.h +55 -0
- data/src/ruby/ext/grpc/extconf.rb +51 -14
- data/src/ruby/ext/grpc/rb_byte_buffer.c +3 -1
- data/src/ruby/ext/grpc/rb_call.c +6 -3
- data/src/ruby/ext/grpc/rb_call_credentials.c +4 -0
- data/src/ruby/ext/grpc/rb_channel.c +4 -2
- data/src/ruby/ext/grpc/rb_channel_args.c +3 -1
- data/src/ruby/ext/grpc/rb_channel_credentials.c +3 -1
- data/src/ruby/ext/grpc/rb_completion_queue.c +3 -1
- data/src/ruby/ext/grpc/rb_event_thread.c +5 -0
- data/src/ruby/ext/grpc/rb_grpc.c +11 -3
- data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +560 -0
- data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +843 -0
- data/src/ruby/ext/grpc/rb_loader.c +72 -0
- data/src/ruby/ext/grpc/rb_loader.h +40 -0
- data/src/ruby/ext/grpc/rb_server.c +3 -1
- data/src/ruby/ext/grpc/rb_server_credentials.c +4 -2
- data/src/ruby/lib/grpc/generic/bidi_call.rb +1 -1
- data/src/ruby/lib/grpc/generic/rpc_desc.rb +1 -1
- data/src/ruby/lib/grpc/generic/rpc_server.rb +1 -1
- data/src/ruby/lib/grpc/grpc.rb +34 -0
- data/src/ruby/lib/grpc/version.rb +1 -1
- data/src/ruby/spec/pb/health/checker_spec.rb +1 -1
- data/third_party/boringssl/crypto/aes/aes.c +1142 -0
- data/third_party/boringssl/crypto/aes/internal.h +87 -0
- data/third_party/boringssl/crypto/aes/mode_wrappers.c +108 -0
- data/third_party/boringssl/crypto/asn1/a_bitstr.c +255 -0
- data/third_party/boringssl/crypto/asn1/a_bool.c +112 -0
- data/third_party/boringssl/crypto/asn1/a_bytes.c +317 -0
- data/third_party/boringssl/crypto/asn1/a_d2i_fp.c +286 -0
- data/third_party/boringssl/crypto/asn1/a_dup.c +103 -0
- data/third_party/boringssl/crypto/asn1/a_enum.c +183 -0
- data/third_party/boringssl/crypto/asn1/a_gentm.c +255 -0
- data/third_party/boringssl/crypto/asn1/a_i2d_fp.c +154 -0
- data/third_party/boringssl/crypto/asn1/a_int.c +456 -0
- data/third_party/boringssl/crypto/asn1/a_mbstr.c +390 -0
- data/third_party/boringssl/crypto/asn1/a_object.c +412 -0
- data/third_party/boringssl/crypto/asn1/a_octet.c +70 -0
- data/third_party/boringssl/crypto/asn1/a_print.c +119 -0
- data/third_party/boringssl/crypto/asn1/a_strnid.c +286 -0
- data/third_party/boringssl/crypto/asn1/a_time.c +221 -0
- data/third_party/boringssl/crypto/asn1/a_type.c +160 -0
- data/third_party/boringssl/crypto/asn1/a_utctm.c +342 -0
- data/third_party/boringssl/crypto/asn1/a_utf8.c +210 -0
- data/third_party/boringssl/crypto/asn1/asn1_lib.c +510 -0
- data/third_party/boringssl/crypto/asn1/asn1_locl.h +73 -0
- data/third_party/boringssl/crypto/asn1/asn1_par.c +444 -0
- data/third_party/boringssl/crypto/asn1/asn_pack.c +104 -0
- data/third_party/boringssl/crypto/asn1/bio_asn1.c +496 -0
- data/third_party/boringssl/crypto/asn1/bio_ndef.c +254 -0
- data/third_party/boringssl/crypto/asn1/f_enum.c +206 -0
- data/third_party/boringssl/crypto/asn1/f_int.c +210 -0
- data/third_party/boringssl/crypto/asn1/f_string.c +204 -0
- data/third_party/boringssl/crypto/asn1/t_bitst.c +102 -0
- data/third_party/boringssl/crypto/asn1/t_pkey.c +112 -0
- data/third_party/boringssl/crypto/asn1/tasn_dec.c +1342 -0
- data/third_party/boringssl/crypto/asn1/tasn_enc.c +695 -0
- data/third_party/boringssl/crypto/asn1/tasn_fre.c +264 -0
- data/third_party/boringssl/crypto/asn1/tasn_new.c +398 -0
- data/third_party/boringssl/crypto/asn1/tasn_prn.c +642 -0
- data/third_party/boringssl/crypto/asn1/tasn_typ.c +137 -0
- data/third_party/boringssl/crypto/asn1/tasn_utl.c +266 -0
- data/third_party/boringssl/crypto/asn1/x_bignum.c +143 -0
- data/third_party/boringssl/crypto/asn1/x_long.c +182 -0
- data/third_party/boringssl/crypto/base64/base64.c +478 -0
- data/third_party/boringssl/crypto/bio/bio.c +608 -0
- data/third_party/boringssl/crypto/bio/bio_mem.c +327 -0
- data/third_party/boringssl/crypto/bio/buffer.c +496 -0
- data/third_party/boringssl/crypto/bio/connect.c +544 -0
- data/third_party/boringssl/crypto/bio/fd.c +270 -0
- data/third_party/boringssl/crypto/bio/file.c +349 -0
- data/third_party/boringssl/crypto/bio/hexdump.c +192 -0
- data/third_party/boringssl/crypto/bio/internal.h +108 -0
- data/third_party/boringssl/crypto/bio/pair.c +803 -0
- data/third_party/boringssl/crypto/bio/printf.c +119 -0
- data/third_party/boringssl/crypto/bio/socket.c +195 -0
- data/third_party/boringssl/crypto/bio/socket_helper.c +113 -0
- data/third_party/boringssl/crypto/bn/add.c +377 -0
- data/third_party/boringssl/crypto/bn/asm/x86_64-gcc.c +599 -0
- data/third_party/boringssl/crypto/bn/bn.c +341 -0
- data/third_party/boringssl/crypto/bn/bn_asn1.c +93 -0
- data/third_party/boringssl/crypto/bn/cmp.c +200 -0
- data/third_party/boringssl/crypto/bn/convert.c +597 -0
- data/third_party/boringssl/crypto/bn/ctx.c +311 -0
- data/third_party/boringssl/crypto/bn/div.c +625 -0
- data/third_party/boringssl/crypto/bn/exponentiation.c +1544 -0
- data/third_party/boringssl/crypto/bn/gcd.c +711 -0
- data/third_party/boringssl/crypto/bn/generic.c +1019 -0
- data/third_party/boringssl/crypto/bn/internal.h +294 -0
- data/third_party/boringssl/crypto/bn/kronecker.c +175 -0
- data/third_party/boringssl/crypto/bn/montgomery.c +561 -0
- data/third_party/boringssl/crypto/bn/mul.c +888 -0
- data/third_party/boringssl/crypto/bn/prime.c +845 -0
- data/third_party/boringssl/crypto/bn/random.c +326 -0
- data/third_party/boringssl/crypto/bn/rsaz_exp.c +326 -0
- data/third_party/boringssl/crypto/bn/rsaz_exp.h +56 -0
- data/third_party/boringssl/crypto/bn/shift.c +299 -0
- data/third_party/boringssl/crypto/bn/sqrt.c +505 -0
- data/third_party/boringssl/crypto/buf/buf.c +235 -0
- data/third_party/boringssl/crypto/bytestring/ber.c +221 -0
- data/third_party/boringssl/crypto/bytestring/cbb.c +411 -0
- data/third_party/boringssl/crypto/bytestring/cbs.c +415 -0
- data/third_party/boringssl/crypto/bytestring/internal.h +46 -0
- data/third_party/boringssl/crypto/chacha/chacha_generic.c +140 -0
- data/third_party/boringssl/crypto/chacha/chacha_vec.c +323 -0
- data/third_party/boringssl/crypto/cipher/aead.c +167 -0
- data/third_party/boringssl/crypto/cipher/cipher.c +652 -0
- data/third_party/boringssl/crypto/cipher/derive_key.c +154 -0
- data/third_party/boringssl/crypto/cipher/e_aes.c +1767 -0
- data/third_party/boringssl/crypto/cipher/e_chacha20poly1305.c +311 -0
- data/third_party/boringssl/crypto/cipher/e_des.c +207 -0
- data/third_party/boringssl/crypto/cipher/e_null.c +85 -0
- data/third_party/boringssl/crypto/cipher/e_rc2.c +443 -0
- data/third_party/boringssl/crypto/cipher/e_rc4.c +87 -0
- data/third_party/boringssl/crypto/cipher/e_ssl3.c +463 -0
- data/third_party/boringssl/crypto/cipher/e_tls.c +673 -0
- data/third_party/boringssl/crypto/cipher/internal.h +164 -0
- data/third_party/boringssl/crypto/cipher/tls_cbc.c +495 -0
- data/third_party/boringssl/crypto/cmac/cmac.c +239 -0
- data/third_party/boringssl/crypto/conf/conf.c +778 -0
- data/third_party/boringssl/crypto/conf/conf_def.h +127 -0
- data/third_party/boringssl/crypto/conf/internal.h +31 -0
- data/third_party/boringssl/crypto/cpu-arm.c +199 -0
- data/third_party/boringssl/crypto/cpu-intel.c +261 -0
- data/third_party/boringssl/crypto/crypto.c +140 -0
- data/third_party/boringssl/crypto/curve25519/curve25519.c +4897 -0
- data/third_party/boringssl/crypto/des/des.c +771 -0
- data/third_party/boringssl/crypto/des/internal.h +212 -0
- data/third_party/boringssl/crypto/dh/check.c +180 -0
- data/third_party/boringssl/crypto/dh/dh.c +463 -0
- data/third_party/boringssl/crypto/dh/dh_asn1.c +84 -0
- data/third_party/boringssl/crypto/dh/internal.h +80 -0
- data/third_party/boringssl/crypto/dh/params.c +301 -0
- data/third_party/boringssl/crypto/digest/digest.c +248 -0
- data/third_party/boringssl/crypto/digest/digests.c +321 -0
- data/third_party/boringssl/crypto/digest/internal.h +112 -0
- data/third_party/boringssl/crypto/digest/md32_common.h +322 -0
- data/third_party/boringssl/crypto/directory.h +66 -0
- data/third_party/boringssl/crypto/directory_posix.c +108 -0
- data/third_party/boringssl/crypto/directory_win.c +144 -0
- data/third_party/boringssl/crypto/dsa/dsa.c +908 -0
- data/third_party/boringssl/crypto/dsa/dsa_asn1.c +150 -0
- data/third_party/boringssl/crypto/dsa/internal.h +78 -0
- data/third_party/boringssl/crypto/ec/ec.c +889 -0
- data/third_party/boringssl/crypto/ec/ec_asn1.c +586 -0
- data/third_party/boringssl/crypto/ec/ec_key.c +482 -0
- data/third_party/boringssl/crypto/ec/ec_montgomery.c +280 -0
- data/third_party/boringssl/crypto/ec/internal.h +318 -0
- data/third_party/boringssl/crypto/ec/oct.c +416 -0
- data/third_party/boringssl/crypto/ec/p224-64.c +1305 -0
- data/third_party/boringssl/crypto/ec/p256-64.c +1878 -0
- data/third_party/boringssl/crypto/ec/p256-x86_64-table.h +9548 -0
- data/third_party/boringssl/crypto/ec/p256-x86_64.c +596 -0
- data/third_party/boringssl/crypto/ec/simple.c +1313 -0
- data/third_party/boringssl/crypto/ec/util-64.c +183 -0
- data/third_party/boringssl/crypto/ec/wnaf.c +449 -0
- data/third_party/boringssl/crypto/ecdh/ecdh.c +153 -0
- data/third_party/boringssl/crypto/ecdsa/ecdsa.c +496 -0
- data/third_party/boringssl/crypto/ecdsa/ecdsa_asn1.c +240 -0
- data/third_party/boringssl/crypto/engine/engine.c +96 -0
- data/third_party/boringssl/crypto/err/err.c +756 -0
- data/third_party/boringssl/crypto/evp/algorithm.c +153 -0
- data/third_party/boringssl/crypto/evp/digestsign.c +159 -0
- data/third_party/boringssl/crypto/evp/evp.c +411 -0
- data/third_party/boringssl/crypto/evp/evp_asn1.c +179 -0
- data/third_party/boringssl/crypto/evp/evp_ctx.c +477 -0
- data/third_party/boringssl/crypto/evp/internal.h +278 -0
- data/third_party/boringssl/crypto/evp/p_dsa_asn1.c +588 -0
- data/third_party/boringssl/crypto/evp/p_ec.c +283 -0
- data/third_party/boringssl/crypto/evp/p_ec_asn1.c +562 -0
- data/third_party/boringssl/crypto/evp/p_rsa.c +596 -0
- data/third_party/boringssl/crypto/evp/p_rsa_asn1.c +737 -0
- data/third_party/boringssl/crypto/evp/pbkdf.c +151 -0
- data/third_party/boringssl/crypto/evp/sign.c +151 -0
- data/third_party/boringssl/crypto/ex_data.c +294 -0
- data/third_party/boringssl/crypto/hkdf/hkdf.c +89 -0
- data/third_party/boringssl/crypto/hmac/hmac.c +213 -0
- data/third_party/boringssl/crypto/internal.h +532 -0
- data/third_party/boringssl/crypto/lhash/lhash.c +346 -0
- data/third_party/boringssl/crypto/md4/md4.c +225 -0
- data/third_party/boringssl/crypto/md5/md5.c +275 -0
- data/third_party/boringssl/crypto/mem.c +200 -0
- data/third_party/boringssl/crypto/modes/cbc.c +216 -0
- data/third_party/boringssl/crypto/modes/cfb.c +231 -0
- data/third_party/boringssl/crypto/modes/ctr.c +226 -0
- data/third_party/boringssl/crypto/modes/gcm.c +1252 -0
- data/third_party/boringssl/crypto/modes/internal.h +370 -0
- data/third_party/boringssl/crypto/modes/ofb.c +108 -0
- data/third_party/boringssl/crypto/obj/obj.c +664 -0
- data/third_party/boringssl/crypto/obj/obj_dat.h +5257 -0
- data/third_party/boringssl/crypto/obj/obj_xref.c +124 -0
- data/third_party/boringssl/crypto/obj/obj_xref.h +96 -0
- data/third_party/boringssl/crypto/pem/pem_all.c +281 -0
- data/third_party/boringssl/crypto/pem/pem_info.c +404 -0
- data/third_party/boringssl/crypto/pem/pem_lib.c +835 -0
- data/third_party/boringssl/crypto/pem/pem_oth.c +89 -0
- data/third_party/boringssl/crypto/pem/pem_pk8.c +244 -0
- data/third_party/boringssl/crypto/pem/pem_pkey.c +312 -0
- data/third_party/boringssl/crypto/pem/pem_x509.c +65 -0
- data/third_party/boringssl/crypto/pem/pem_xaux.c +66 -0
- data/third_party/boringssl/crypto/pkcs8/internal.h +83 -0
- data/third_party/boringssl/crypto/pkcs8/p5_pbe.c +150 -0
- data/third_party/boringssl/crypto/pkcs8/p5_pbev2.c +440 -0
- data/third_party/boringssl/crypto/pkcs8/p8_pkey.c +85 -0
- data/third_party/boringssl/crypto/pkcs8/pkcs8.c +1217 -0
- data/third_party/boringssl/crypto/poly1305/poly1305.c +331 -0
- data/third_party/boringssl/crypto/poly1305/poly1305_arm.c +301 -0
- data/third_party/boringssl/crypto/poly1305/poly1305_vec.c +892 -0
- data/third_party/boringssl/crypto/rand/internal.h +32 -0
- data/third_party/boringssl/crypto/rand/rand.c +239 -0
- data/third_party/boringssl/crypto/rand/urandom.c +223 -0
- data/third_party/boringssl/crypto/rand/windows.c +56 -0
- data/third_party/boringssl/crypto/rc4/rc4.c +283 -0
- data/third_party/boringssl/crypto/refcount_c11.c +67 -0
- data/third_party/boringssl/crypto/refcount_lock.c +53 -0
- data/third_party/boringssl/crypto/rsa/blinding.c +462 -0
- data/third_party/boringssl/crypto/rsa/internal.h +164 -0
- data/third_party/boringssl/crypto/rsa/padding.c +711 -0
- data/third_party/boringssl/crypto/rsa/rsa.c +808 -0
- data/third_party/boringssl/crypto/rsa/rsa_asn1.c +473 -0
- data/third_party/boringssl/crypto/rsa/rsa_impl.c +1138 -0
- data/third_party/boringssl/crypto/sha/sha1.c +337 -0
- data/third_party/boringssl/crypto/sha/sha256.c +327 -0
- data/third_party/boringssl/crypto/sha/sha512.c +607 -0
- data/third_party/boringssl/crypto/stack/stack.c +386 -0
- data/third_party/boringssl/crypto/test/scoped_types.h +137 -0
- data/third_party/boringssl/crypto/test/test_util.h +35 -0
- data/third_party/boringssl/crypto/thread.c +101 -0
- data/third_party/boringssl/crypto/thread_none.c +55 -0
- data/third_party/boringssl/crypto/thread_pthread.c +167 -0
- data/third_party/boringssl/crypto/thread_win.c +282 -0
- data/third_party/boringssl/crypto/time_support.c +212 -0
- data/third_party/boringssl/crypto/x509/a_digest.c +97 -0
- data/third_party/boringssl/crypto/x509/a_sign.c +136 -0
- data/third_party/boringssl/crypto/x509/a_strex.c +564 -0
- data/third_party/boringssl/crypto/x509/a_verify.c +133 -0
- data/third_party/boringssl/crypto/x509/asn1_gen.c +873 -0
- data/third_party/boringssl/crypto/x509/by_dir.c +491 -0
- data/third_party/boringssl/crypto/x509/by_file.c +295 -0
- data/third_party/boringssl/crypto/x509/charmap.h +15 -0
- data/third_party/boringssl/crypto/x509/i2d_pr.c +84 -0
- data/third_party/boringssl/crypto/x509/pkcs7.c +353 -0
- data/third_party/boringssl/crypto/x509/t_crl.c +129 -0
- data/third_party/boringssl/crypto/x509/t_req.c +246 -0
- data/third_party/boringssl/crypto/x509/t_x509.c +500 -0
- data/third_party/boringssl/crypto/x509/t_x509a.c +109 -0
- data/third_party/boringssl/crypto/x509/vpm_int.h +70 -0
- data/third_party/boringssl/crypto/x509/x509.c +152 -0
- data/third_party/boringssl/crypto/x509/x509_att.c +353 -0
- data/third_party/boringssl/crypto/x509/x509_cmp.c +490 -0
- data/third_party/boringssl/crypto/x509/x509_d2.c +105 -0
- data/third_party/boringssl/crypto/x509/x509_def.c +88 -0
- data/third_party/boringssl/crypto/x509/x509_ext.c +206 -0
- data/third_party/boringssl/crypto/x509/x509_lu.c +738 -0
- data/third_party/boringssl/crypto/x509/x509_obj.c +191 -0
- data/third_party/boringssl/crypto/x509/x509_r2x.c +113 -0
- data/third_party/boringssl/crypto/x509/x509_req.c +315 -0
- data/third_party/boringssl/crypto/x509/x509_set.c +154 -0
- data/third_party/boringssl/crypto/x509/x509_trs.c +304 -0
- data/third_party/boringssl/crypto/x509/x509_txt.c +209 -0
- data/third_party/boringssl/crypto/x509/x509_v3.c +271 -0
- data/third_party/boringssl/crypto/x509/x509_vfy.c +2456 -0
- data/third_party/boringssl/crypto/x509/x509_vpm.c +672 -0
- data/third_party/boringssl/crypto/x509/x509cset.c +172 -0
- data/third_party/boringssl/crypto/x509/x509name.c +381 -0
- data/third_party/boringssl/crypto/x509/x509rset.c +80 -0
- data/third_party/boringssl/crypto/x509/x509spki.c +135 -0
- data/third_party/boringssl/crypto/x509/x509type.c +128 -0
- data/third_party/boringssl/crypto/x509/x_algor.c +154 -0
- data/third_party/boringssl/crypto/x509/x_all.c +547 -0
- data/third_party/boringssl/crypto/x509/x_attrib.c +117 -0
- data/third_party/boringssl/crypto/x509/x_crl.c +560 -0
- data/third_party/boringssl/crypto/x509/x_exten.c +75 -0
- data/third_party/boringssl/crypto/x509/x_info.c +95 -0
- data/third_party/boringssl/crypto/x509/x_name.c +538 -0
- data/third_party/boringssl/crypto/x509/x_pkey.c +100 -0
- data/third_party/boringssl/crypto/x509/x_pubkey.c +384 -0
- data/third_party/boringssl/crypto/x509/x_req.c +112 -0
- data/third_party/boringssl/crypto/x509/x_sig.c +69 -0
- data/third_party/boringssl/crypto/x509/x_spki.c +78 -0
- data/third_party/boringssl/crypto/x509/x_val.c +69 -0
- data/third_party/boringssl/crypto/x509/x_x509.c +227 -0
- data/third_party/boringssl/crypto/x509/x_x509a.c +197 -0
- data/third_party/boringssl/crypto/x509v3/ext_dat.h +129 -0
- data/third_party/boringssl/crypto/x509v3/pcy_cache.c +299 -0
- data/third_party/boringssl/crypto/x509v3/pcy_data.c +137 -0
- data/third_party/boringssl/crypto/x509v3/pcy_int.h +212 -0
- data/third_party/boringssl/crypto/x509v3/pcy_lib.c +165 -0
- data/third_party/boringssl/crypto/x509v3/pcy_map.c +133 -0
- data/third_party/boringssl/crypto/x509v3/pcy_node.c +197 -0
- data/third_party/boringssl/crypto/x509v3/pcy_tree.c +876 -0
- data/third_party/boringssl/crypto/x509v3/v3_akey.c +212 -0
- data/third_party/boringssl/crypto/x509v3/v3_akeya.c +71 -0
- data/third_party/boringssl/crypto/x509v3/v3_alt.c +622 -0
- data/third_party/boringssl/crypto/x509v3/v3_bcons.c +126 -0
- data/third_party/boringssl/crypto/x509v3/v3_bitst.c +141 -0
- data/third_party/boringssl/crypto/x509v3/v3_conf.c +459 -0
- data/third_party/boringssl/crypto/x509v3/v3_cpols.c +475 -0
- data/third_party/boringssl/crypto/x509v3/v3_crld.c +616 -0
- data/third_party/boringssl/crypto/x509v3/v3_enum.c +98 -0
- data/third_party/boringssl/crypto/x509v3/v3_extku.c +145 -0
- data/third_party/boringssl/crypto/x509v3/v3_genn.c +252 -0
- data/third_party/boringssl/crypto/x509v3/v3_ia5.c +117 -0
- data/third_party/boringssl/crypto/x509v3/v3_info.c +200 -0
- data/third_party/boringssl/crypto/x509v3/v3_int.c +87 -0
- data/third_party/boringssl/crypto/x509v3/v3_lib.c +335 -0
- data/third_party/boringssl/crypto/x509v3/v3_ncons.c +510 -0
- data/third_party/boringssl/crypto/x509v3/v3_pci.c +335 -0
- data/third_party/boringssl/crypto/x509v3/v3_pcia.c +56 -0
- data/third_party/boringssl/crypto/x509v3/v3_pcons.c +142 -0
- data/third_party/boringssl/crypto/x509v3/v3_pku.c +109 -0
- data/third_party/boringssl/crypto/x509v3/v3_pmaps.c +156 -0
- data/third_party/boringssl/crypto/x509v3/v3_prn.c +207 -0
- data/third_party/boringssl/crypto/x509v3/v3_purp.c +805 -0
- data/third_party/boringssl/crypto/x509v3/v3_skey.c +148 -0
- data/third_party/boringssl/crypto/x509v3/v3_sxnet.c +266 -0
- data/third_party/boringssl/crypto/x509v3/v3_utl.c +1322 -0
- data/third_party/boringssl/include/openssl/aead.h +346 -0
- data/third_party/boringssl/include/openssl/aes.h +158 -0
- data/third_party/boringssl/include/openssl/arm_arch.h +127 -0
- data/third_party/boringssl/include/openssl/asn1.h +1168 -0
- data/third_party/boringssl/include/openssl/asn1_mac.h +75 -0
- data/third_party/boringssl/include/openssl/asn1t.h +906 -0
- data/third_party/boringssl/include/openssl/base.h +261 -0
- data/third_party/boringssl/include/openssl/base64.h +184 -0
- data/third_party/boringssl/include/openssl/bio.h +902 -0
- data/third_party/boringssl/include/openssl/blowfish.h +93 -0
- data/third_party/boringssl/include/openssl/bn.h +885 -0
- data/third_party/boringssl/include/openssl/buf.h +118 -0
- data/third_party/boringssl/include/openssl/buffer.h +18 -0
- data/third_party/boringssl/include/openssl/bytestring.h +360 -0
- data/third_party/boringssl/include/openssl/cast.h +96 -0
- data/third_party/boringssl/include/openssl/chacha.h +37 -0
- data/third_party/boringssl/include/openssl/cipher.h +571 -0
- data/third_party/boringssl/include/openssl/cmac.h +76 -0
- data/third_party/boringssl/include/openssl/conf.h +145 -0
- data/third_party/boringssl/include/openssl/cpu.h +184 -0
- data/third_party/boringssl/include/openssl/crypto.h +68 -0
- data/third_party/boringssl/include/openssl/curve25519.h +88 -0
- data/third_party/boringssl/include/openssl/des.h +177 -0
- data/third_party/boringssl/include/openssl/dh.h +238 -0
- data/third_party/boringssl/include/openssl/digest.h +258 -0
- data/third_party/boringssl/include/openssl/dsa.h +343 -0
- data/third_party/boringssl/include/openssl/dtls1.h +16 -0
- data/third_party/boringssl/include/openssl/ec.h +355 -0
- data/third_party/boringssl/include/openssl/ec_key.h +280 -0
- data/third_party/boringssl/include/openssl/ecdh.h +102 -0
- data/third_party/boringssl/include/openssl/ecdsa.h +206 -0
- data/third_party/boringssl/include/openssl/engine.h +98 -0
- data/third_party/boringssl/include/openssl/err.h +487 -0
- data/third_party/boringssl/include/openssl/evp.h +750 -0
- data/third_party/boringssl/include/openssl/ex_data.h +213 -0
- data/third_party/boringssl/include/openssl/hkdf.h +44 -0
- data/third_party/boringssl/include/openssl/hmac.h +160 -0
- data/third_party/boringssl/include/openssl/lhash.h +192 -0
- data/third_party/boringssl/include/openssl/lhash_macros.h +132 -0
- data/third_party/boringssl/include/openssl/md4.h +102 -0
- data/third_party/boringssl/include/openssl/md5.h +107 -0
- data/third_party/boringssl/include/openssl/mem.h +140 -0
- data/third_party/boringssl/include/openssl/obj.h +198 -0
- data/third_party/boringssl/include/openssl/obj_mac.h +4140 -0
- data/third_party/boringssl/include/openssl/objects.h +18 -0
- data/third_party/boringssl/include/openssl/opensslfeatures.h +60 -0
- data/third_party/boringssl/include/openssl/opensslv.h +18 -0
- data/third_party/boringssl/include/openssl/ossl_typ.h +18 -0
- data/third_party/boringssl/include/openssl/pem.h +521 -0
- data/third_party/boringssl/include/openssl/pkcs12.h +18 -0
- data/third_party/boringssl/include/openssl/pkcs7.h +16 -0
- data/third_party/boringssl/include/openssl/pkcs8.h +220 -0
- data/third_party/boringssl/include/openssl/poly1305.h +51 -0
- data/third_party/boringssl/include/openssl/pqueue.h +146 -0
- data/third_party/boringssl/include/openssl/rand.h +113 -0
- data/third_party/boringssl/include/openssl/rc4.h +90 -0
- data/third_party/boringssl/include/openssl/rsa.h +637 -0
- data/third_party/boringssl/include/openssl/safestack.h +16 -0
- data/third_party/boringssl/include/openssl/sha.h +256 -0
- data/third_party/boringssl/include/openssl/srtp.h +18 -0
- data/third_party/boringssl/include/openssl/ssl.h +4466 -0
- data/third_party/boringssl/include/openssl/ssl3.h +441 -0
- data/third_party/boringssl/include/openssl/stack.h +298 -0
- data/third_party/boringssl/include/openssl/stack_macros.h +4190 -0
- data/third_party/boringssl/include/openssl/thread.h +173 -0
- data/third_party/boringssl/include/openssl/time_support.h +90 -0
- data/third_party/boringssl/include/openssl/tls1.h +653 -0
- data/third_party/boringssl/include/openssl/type_check.h +91 -0
- data/third_party/boringssl/include/openssl/x509.h +1258 -0
- data/third_party/boringssl/include/openssl/x509_vfy.h +611 -0
- data/third_party/boringssl/include/openssl/x509v3.h +798 -0
- data/third_party/boringssl/ssl/custom_extensions.c +257 -0
- data/third_party/boringssl/ssl/d1_both.c +880 -0
- data/third_party/boringssl/ssl/d1_clnt.c +566 -0
- data/third_party/boringssl/ssl/d1_lib.c +340 -0
- data/third_party/boringssl/ssl/d1_meth.c +130 -0
- data/third_party/boringssl/ssl/d1_pkt.c +578 -0
- data/third_party/boringssl/ssl/d1_srtp.c +234 -0
- data/third_party/boringssl/ssl/d1_srvr.c +485 -0
- data/third_party/boringssl/ssl/dtls_record.c +308 -0
- data/third_party/boringssl/ssl/internal.h +1276 -0
- data/third_party/boringssl/ssl/pqueue/pqueue.c +197 -0
- data/third_party/boringssl/ssl/s3_both.c +571 -0
- data/third_party/boringssl/ssl/s3_clnt.c +2241 -0
- data/third_party/boringssl/ssl/s3_enc.c +494 -0
- data/third_party/boringssl/ssl/s3_lib.c +587 -0
- data/third_party/boringssl/ssl/s3_meth.c +166 -0
- data/third_party/boringssl/ssl/s3_pkt.c +732 -0
- data/third_party/boringssl/ssl/s3_srvr.c +2536 -0
- data/third_party/boringssl/ssl/ssl_aead_ctx.c +300 -0
- data/third_party/boringssl/ssl/ssl_asn1.c +718 -0
- data/third_party/boringssl/ssl/ssl_buffer.c +319 -0
- data/third_party/boringssl/ssl/ssl_cert.c +539 -0
- data/third_party/boringssl/ssl/ssl_cipher.c +2003 -0
- data/third_party/boringssl/ssl/ssl_file.c +633 -0
- data/third_party/boringssl/ssl/ssl_lib.c +2653 -0
- data/third_party/boringssl/ssl/ssl_rsa.c +423 -0
- data/third_party/boringssl/ssl/ssl_session.c +764 -0
- data/third_party/boringssl/ssl/ssl_stat.c +591 -0
- data/third_party/boringssl/ssl/t1_enc.c +708 -0
- data/third_party/boringssl/ssl/t1_lib.c +2905 -0
- data/third_party/boringssl/ssl/test/async_bio.h +45 -0
- data/third_party/boringssl/ssl/test/packeted_bio.h +44 -0
- data/third_party/boringssl/ssl/test/scoped_types.h +28 -0
- data/third_party/boringssl/ssl/test/test_config.h +108 -0
- data/third_party/boringssl/ssl/tls_record.c +342 -0
- data/third_party/zlib/adler32.c +179 -0
- data/third_party/zlib/compress.c +80 -0
- data/third_party/zlib/crc32.c +425 -0
- data/third_party/zlib/crc32.h +441 -0
- data/third_party/zlib/deflate.c +1967 -0
- data/third_party/zlib/deflate.h +346 -0
- data/third_party/zlib/gzclose.c +25 -0
- data/third_party/zlib/gzguts.h +209 -0
- data/third_party/zlib/gzlib.c +634 -0
- data/third_party/zlib/gzread.c +594 -0
- data/third_party/zlib/gzwrite.c +577 -0
- data/third_party/zlib/infback.c +640 -0
- data/third_party/zlib/inffast.c +340 -0
- data/third_party/zlib/inffast.h +11 -0
- data/third_party/zlib/inffixed.h +94 -0
- data/third_party/zlib/inflate.c +1512 -0
- data/third_party/zlib/inflate.h +122 -0
- data/third_party/zlib/inftrees.c +306 -0
- data/third_party/zlib/inftrees.h +62 -0
- data/third_party/zlib/trees.c +1226 -0
- data/third_party/zlib/trees.h +128 -0
- data/third_party/zlib/uncompr.c +59 -0
- data/third_party/zlib/zconf.h +511 -0
- data/third_party/zlib/zlib.h +1768 -0
- data/third_party/zlib/zutil.c +324 -0
- data/third_party/zlib/zutil.h +253 -0
- metadata +492 -25
- data/Rakefile +0 -63
- data/src/ruby/lib/grpc/grpc.so +0 -0
@@ -0,0 +1,441 @@
|
|
1
|
+
/* ssl/ssl3.h */
|
2
|
+
/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
|
3
|
+
* All rights reserved.
|
4
|
+
*
|
5
|
+
* This package is an SSL implementation written
|
6
|
+
* by Eric Young (eay@cryptsoft.com).
|
7
|
+
* The implementation was written so as to conform with Netscapes SSL.
|
8
|
+
*
|
9
|
+
* This library is free for commercial and non-commercial use as long as
|
10
|
+
* the following conditions are aheared to. The following conditions
|
11
|
+
* apply to all code found in this distribution, be it the RC4, RSA,
|
12
|
+
* lhash, DES, etc., code; not just the SSL code. The SSL documentation
|
13
|
+
* included with this distribution is covered by the same copyright terms
|
14
|
+
* except that the holder is Tim Hudson (tjh@cryptsoft.com).
|
15
|
+
*
|
16
|
+
* Copyright remains Eric Young's, and as such any Copyright notices in
|
17
|
+
* the code are not to be removed.
|
18
|
+
* If this package is used in a product, Eric Young should be given attribution
|
19
|
+
* as the author of the parts of the library used.
|
20
|
+
* This can be in the form of a textual message at program startup or
|
21
|
+
* in documentation (online or textual) provided with the package.
|
22
|
+
*
|
23
|
+
* Redistribution and use in source and binary forms, with or without
|
24
|
+
* modification, are permitted provided that the following conditions
|
25
|
+
* are met:
|
26
|
+
* 1. Redistributions of source code must retain the copyright
|
27
|
+
* notice, this list of conditions and the following disclaimer.
|
28
|
+
* 2. Redistributions in binary form must reproduce the above copyright
|
29
|
+
* notice, this list of conditions and the following disclaimer in the
|
30
|
+
* documentation and/or other materials provided with the distribution.
|
31
|
+
* 3. All advertising materials mentioning features or use of this software
|
32
|
+
* must display the following acknowledgement:
|
33
|
+
* "This product includes cryptographic software written by
|
34
|
+
* Eric Young (eay@cryptsoft.com)"
|
35
|
+
* The word 'cryptographic' can be left out if the rouines from the library
|
36
|
+
* being used are not cryptographic related :-).
|
37
|
+
* 4. If you include any Windows specific code (or a derivative thereof) from
|
38
|
+
* the apps directory (application code) you must include an acknowledgement:
|
39
|
+
* "This product includes software written by Tim Hudson (tjh@cryptsoft.com)"
|
40
|
+
*
|
41
|
+
* THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND
|
42
|
+
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
43
|
+
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
44
|
+
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
45
|
+
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
46
|
+
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
47
|
+
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
48
|
+
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
49
|
+
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
50
|
+
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
51
|
+
* SUCH DAMAGE.
|
52
|
+
*
|
53
|
+
* The licence and distribution terms for any publically available version or
|
54
|
+
* derivative of this code cannot be changed. i.e. this code cannot simply be
|
55
|
+
* copied and put under another distribution licence
|
56
|
+
* [including the GNU Public Licence.]
|
57
|
+
*/
|
58
|
+
/* ====================================================================
|
59
|
+
* Copyright (c) 1998-2002 The OpenSSL Project. All rights reserved.
|
60
|
+
*
|
61
|
+
* Redistribution and use in source and binary forms, with or without
|
62
|
+
* modification, are permitted provided that the following conditions
|
63
|
+
* are met:
|
64
|
+
*
|
65
|
+
* 1. Redistributions of source code must retain the above copyright
|
66
|
+
* notice, this list of conditions and the following disclaimer.
|
67
|
+
*
|
68
|
+
* 2. Redistributions in binary form must reproduce the above copyright
|
69
|
+
* notice, this list of conditions and the following disclaimer in
|
70
|
+
* the documentation and/or other materials provided with the
|
71
|
+
* distribution.
|
72
|
+
*
|
73
|
+
* 3. All advertising materials mentioning features or use of this
|
74
|
+
* software must display the following acknowledgment:
|
75
|
+
* "This product includes software developed by the OpenSSL Project
|
76
|
+
* for use in the OpenSSL Toolkit. (http://www.openssl.org/)"
|
77
|
+
*
|
78
|
+
* 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to
|
79
|
+
* endorse or promote products derived from this software without
|
80
|
+
* prior written permission. For written permission, please contact
|
81
|
+
* openssl-core@openssl.org.
|
82
|
+
*
|
83
|
+
* 5. Products derived from this software may not be called "OpenSSL"
|
84
|
+
* nor may "OpenSSL" appear in their names without prior written
|
85
|
+
* permission of the OpenSSL Project.
|
86
|
+
*
|
87
|
+
* 6. Redistributions of any form whatsoever must retain the following
|
88
|
+
* acknowledgment:
|
89
|
+
* "This product includes software developed by the OpenSSL Project
|
90
|
+
* for use in the OpenSSL Toolkit (http://www.openssl.org/)"
|
91
|
+
*
|
92
|
+
* THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY
|
93
|
+
* EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
94
|
+
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
95
|
+
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE OpenSSL PROJECT OR
|
96
|
+
* ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
97
|
+
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
98
|
+
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
99
|
+
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
100
|
+
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
|
101
|
+
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
102
|
+
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
|
103
|
+
* OF THE POSSIBILITY OF SUCH DAMAGE.
|
104
|
+
* ====================================================================
|
105
|
+
*
|
106
|
+
* This product includes cryptographic software written by Eric Young
|
107
|
+
* (eay@cryptsoft.com). This product includes software written by Tim
|
108
|
+
* Hudson (tjh@cryptsoft.com).
|
109
|
+
*
|
110
|
+
*/
|
111
|
+
/* ====================================================================
|
112
|
+
* Copyright 2002 Sun Microsystems, Inc. ALL RIGHTS RESERVED.
|
113
|
+
* ECC cipher suite support in OpenSSL originally developed by
|
114
|
+
* SUN MICROSYSTEMS, INC., and contributed to the OpenSSL project.
|
115
|
+
*/
|
116
|
+
|
117
|
+
#ifndef OPENSSL_HEADER_SSL3_H
|
118
|
+
#define OPENSSL_HEADER_SSL3_H
|
119
|
+
|
120
|
+
#include <openssl/aead.h>
|
121
|
+
#include <openssl/type_check.h>
|
122
|
+
|
123
|
+
#ifdef __cplusplus
|
124
|
+
extern "C" {
|
125
|
+
#endif
|
126
|
+
|
127
|
+
|
128
|
+
/* These are kept to support clients that negotiates higher protocol versions
|
129
|
+
* using SSLv2 client hello records. */
|
130
|
+
#define SSL2_MT_CLIENT_HELLO 1
|
131
|
+
#define SSL2_VERSION 0x0002
|
132
|
+
|
133
|
+
/* Signalling cipher suite value from RFC 5746. */
|
134
|
+
#define SSL3_CK_SCSV 0x030000FF
|
135
|
+
/* Fallback signalling cipher suite value from RFC 7507. */
|
136
|
+
#define SSL3_CK_FALLBACK_SCSV 0x03005600
|
137
|
+
|
138
|
+
#define SSL3_CK_RSA_NULL_MD5 0x03000001
|
139
|
+
#define SSL3_CK_RSA_NULL_SHA 0x03000002
|
140
|
+
#define SSL3_CK_RSA_RC4_40_MD5 0x03000003
|
141
|
+
#define SSL3_CK_RSA_RC4_128_MD5 0x03000004
|
142
|
+
#define SSL3_CK_RSA_RC4_128_SHA 0x03000005
|
143
|
+
#define SSL3_CK_RSA_RC2_40_MD5 0x03000006
|
144
|
+
#define SSL3_CK_RSA_IDEA_128_SHA 0x03000007
|
145
|
+
#define SSL3_CK_RSA_DES_40_CBC_SHA 0x03000008
|
146
|
+
#define SSL3_CK_RSA_DES_64_CBC_SHA 0x03000009
|
147
|
+
#define SSL3_CK_RSA_DES_192_CBC3_SHA 0x0300000A
|
148
|
+
|
149
|
+
#define SSL3_CK_DH_DSS_DES_40_CBC_SHA 0x0300000B
|
150
|
+
#define SSL3_CK_DH_DSS_DES_64_CBC_SHA 0x0300000C
|
151
|
+
#define SSL3_CK_DH_DSS_DES_192_CBC3_SHA 0x0300000D
|
152
|
+
#define SSL3_CK_DH_RSA_DES_40_CBC_SHA 0x0300000E
|
153
|
+
#define SSL3_CK_DH_RSA_DES_64_CBC_SHA 0x0300000F
|
154
|
+
#define SSL3_CK_DH_RSA_DES_192_CBC3_SHA 0x03000010
|
155
|
+
|
156
|
+
#define SSL3_CK_EDH_DSS_DES_40_CBC_SHA 0x03000011
|
157
|
+
#define SSL3_CK_EDH_DSS_DES_64_CBC_SHA 0x03000012
|
158
|
+
#define SSL3_CK_EDH_DSS_DES_192_CBC3_SHA 0x03000013
|
159
|
+
#define SSL3_CK_EDH_RSA_DES_40_CBC_SHA 0x03000014
|
160
|
+
#define SSL3_CK_EDH_RSA_DES_64_CBC_SHA 0x03000015
|
161
|
+
#define SSL3_CK_EDH_RSA_DES_192_CBC3_SHA 0x03000016
|
162
|
+
|
163
|
+
#define SSL3_CK_ADH_RC4_40_MD5 0x03000017
|
164
|
+
#define SSL3_CK_ADH_RC4_128_MD5 0x03000018
|
165
|
+
#define SSL3_CK_ADH_DES_40_CBC_SHA 0x03000019
|
166
|
+
#define SSL3_CK_ADH_DES_64_CBC_SHA 0x0300001A
|
167
|
+
#define SSL3_CK_ADH_DES_192_CBC_SHA 0x0300001B
|
168
|
+
|
169
|
+
#define SSL3_TXT_RSA_NULL_MD5 "NULL-MD5"
|
170
|
+
#define SSL3_TXT_RSA_NULL_SHA "NULL-SHA"
|
171
|
+
#define SSL3_TXT_RSA_RC4_40_MD5 "EXP-RC4-MD5"
|
172
|
+
#define SSL3_TXT_RSA_RC4_128_MD5 "RC4-MD5"
|
173
|
+
#define SSL3_TXT_RSA_RC4_128_SHA "RC4-SHA"
|
174
|
+
#define SSL3_TXT_RSA_RC2_40_MD5 "EXP-RC2-CBC-MD5"
|
175
|
+
#define SSL3_TXT_RSA_IDEA_128_SHA "IDEA-CBC-SHA"
|
176
|
+
#define SSL3_TXT_RSA_DES_40_CBC_SHA "EXP-DES-CBC-SHA"
|
177
|
+
#define SSL3_TXT_RSA_DES_64_CBC_SHA "DES-CBC-SHA"
|
178
|
+
#define SSL3_TXT_RSA_DES_192_CBC3_SHA "DES-CBC3-SHA"
|
179
|
+
|
180
|
+
#define SSL3_TXT_DH_DSS_DES_40_CBC_SHA "EXP-DH-DSS-DES-CBC-SHA"
|
181
|
+
#define SSL3_TXT_DH_DSS_DES_64_CBC_SHA "DH-DSS-DES-CBC-SHA"
|
182
|
+
#define SSL3_TXT_DH_DSS_DES_192_CBC3_SHA "DH-DSS-DES-CBC3-SHA"
|
183
|
+
#define SSL3_TXT_DH_RSA_DES_40_CBC_SHA "EXP-DH-RSA-DES-CBC-SHA"
|
184
|
+
#define SSL3_TXT_DH_RSA_DES_64_CBC_SHA "DH-RSA-DES-CBC-SHA"
|
185
|
+
#define SSL3_TXT_DH_RSA_DES_192_CBC3_SHA "DH-RSA-DES-CBC3-SHA"
|
186
|
+
|
187
|
+
#define SSL3_TXT_EDH_DSS_DES_40_CBC_SHA "EXP-EDH-DSS-DES-CBC-SHA"
|
188
|
+
#define SSL3_TXT_EDH_DSS_DES_64_CBC_SHA "EDH-DSS-DES-CBC-SHA"
|
189
|
+
#define SSL3_TXT_EDH_DSS_DES_192_CBC3_SHA "EDH-DSS-DES-CBC3-SHA"
|
190
|
+
#define SSL3_TXT_EDH_RSA_DES_40_CBC_SHA "EXP-EDH-RSA-DES-CBC-SHA"
|
191
|
+
#define SSL3_TXT_EDH_RSA_DES_64_CBC_SHA "EDH-RSA-DES-CBC-SHA"
|
192
|
+
#define SSL3_TXT_EDH_RSA_DES_192_CBC3_SHA "EDH-RSA-DES-CBC3-SHA"
|
193
|
+
|
194
|
+
#define SSL3_TXT_ADH_RC4_40_MD5 "EXP-ADH-RC4-MD5"
|
195
|
+
#define SSL3_TXT_ADH_RC4_128_MD5 "ADH-RC4-MD5"
|
196
|
+
#define SSL3_TXT_ADH_DES_40_CBC_SHA "EXP-ADH-DES-CBC-SHA"
|
197
|
+
#define SSL3_TXT_ADH_DES_64_CBC_SHA "ADH-DES-CBC-SHA"
|
198
|
+
#define SSL3_TXT_ADH_DES_192_CBC_SHA "ADH-DES-CBC3-SHA"
|
199
|
+
|
200
|
+
#define SSL3_SSL_SESSION_ID_LENGTH 32
|
201
|
+
#define SSL3_MAX_SSL_SESSION_ID_LENGTH 32
|
202
|
+
|
203
|
+
#define SSL3_MASTER_SECRET_SIZE 48
|
204
|
+
#define SSL3_RANDOM_SIZE 32
|
205
|
+
#define SSL3_SESSION_ID_SIZE 32
|
206
|
+
#define SSL3_RT_HEADER_LENGTH 5
|
207
|
+
|
208
|
+
#define SSL3_HM_HEADER_LENGTH 4
|
209
|
+
|
210
|
+
#ifndef SSL3_ALIGN_PAYLOAD
|
211
|
+
/* Some will argue that this increases memory footprint, but it's not actually
|
212
|
+
* true. Point is that malloc has to return at least 64-bit aligned pointers,
|
213
|
+
* meaning that allocating 5 bytes wastes 3 bytes in either case. Suggested
|
214
|
+
* pre-gaping simply moves these wasted bytes from the end of allocated region
|
215
|
+
* to its front, but makes data payload aligned, which improves performance. */
|
216
|
+
#define SSL3_ALIGN_PAYLOAD 8
|
217
|
+
#else
|
218
|
+
#if (SSL3_ALIGN_PAYLOAD & (SSL3_ALIGN_PAYLOAD - 1)) != 0
|
219
|
+
#error "insane SSL3_ALIGN_PAYLOAD"
|
220
|
+
#undef SSL3_ALIGN_PAYLOAD
|
221
|
+
#endif
|
222
|
+
#endif
|
223
|
+
|
224
|
+
/* This is the maximum MAC (digest) size used by the SSL library. Currently
|
225
|
+
* maximum of 20 is used by SHA1, but we reserve for future extension for
|
226
|
+
* 512-bit hashes. */
|
227
|
+
|
228
|
+
#define SSL3_RT_MAX_MD_SIZE 64
|
229
|
+
|
230
|
+
/* Maximum block size used in all ciphersuites. Currently 16 for AES. */
|
231
|
+
|
232
|
+
#define SSL_RT_MAX_CIPHER_BLOCK_SIZE 16
|
233
|
+
|
234
|
+
/* Maximum plaintext length: defined by SSL/TLS standards */
|
235
|
+
#define SSL3_RT_MAX_PLAIN_LENGTH 16384
|
236
|
+
/* Maximum compression overhead: defined by SSL/TLS standards */
|
237
|
+
#define SSL3_RT_MAX_COMPRESSED_OVERHEAD 1024
|
238
|
+
|
239
|
+
/* The standards give a maximum encryption overhead of 1024 bytes. In practice
|
240
|
+
* the value is lower than this. The overhead is the maximum number of padding
|
241
|
+
* bytes (256) plus the mac size.
|
242
|
+
*
|
243
|
+
* TODO(davidben): This derivation doesn't take AEADs into account, or TLS 1.1
|
244
|
+
* explicit nonces. It happens to work because |SSL3_RT_MAX_MD_SIZE| is larger
|
245
|
+
* than necessary and no true AEAD has variable overhead in TLS 1.2. */
|
246
|
+
#define SSL3_RT_MAX_ENCRYPTED_OVERHEAD (256 + SSL3_RT_MAX_MD_SIZE)
|
247
|
+
|
248
|
+
/* SSL3_RT_SEND_MAX_ENCRYPTED_OVERHEAD is the maximum overhead in encrypting a
|
249
|
+
* record. This does not include the record header. Some ciphers use explicit
|
250
|
+
* nonces, so it includes both the AEAD overhead as well as the nonce. */
|
251
|
+
#define SSL3_RT_SEND_MAX_ENCRYPTED_OVERHEAD \
|
252
|
+
(EVP_AEAD_MAX_OVERHEAD + EVP_AEAD_MAX_NONCE_LENGTH)
|
253
|
+
|
254
|
+
OPENSSL_COMPILE_ASSERT(
|
255
|
+
SSL3_RT_MAX_ENCRYPTED_OVERHEAD >= SSL3_RT_SEND_MAX_ENCRYPTED_OVERHEAD,
|
256
|
+
max_overheads_are_consistent);
|
257
|
+
|
258
|
+
/* SSL3_RT_MAX_COMPRESSED_LENGTH is an alias for
|
259
|
+
* |SSL3_RT_MAX_PLAIN_LENGTH|. Compression is gone, so don't include the
|
260
|
+
* compression overhead. */
|
261
|
+
#define SSL3_RT_MAX_COMPRESSED_LENGTH SSL3_RT_MAX_PLAIN_LENGTH
|
262
|
+
|
263
|
+
#define SSL3_RT_MAX_ENCRYPTED_LENGTH \
|
264
|
+
(SSL3_RT_MAX_ENCRYPTED_OVERHEAD + SSL3_RT_MAX_COMPRESSED_LENGTH)
|
265
|
+
#define SSL3_RT_MAX_PACKET_SIZE \
|
266
|
+
(SSL3_RT_MAX_ENCRYPTED_LENGTH + SSL3_RT_HEADER_LENGTH)
|
267
|
+
|
268
|
+
#define SSL3_MD_CLIENT_FINISHED_CONST "\x43\x4C\x4E\x54"
|
269
|
+
#define SSL3_MD_SERVER_FINISHED_CONST "\x53\x52\x56\x52"
|
270
|
+
|
271
|
+
#define SSL3_RT_CHANGE_CIPHER_SPEC 20
|
272
|
+
#define SSL3_RT_ALERT 21
|
273
|
+
#define SSL3_RT_HANDSHAKE 22
|
274
|
+
#define SSL3_RT_APPLICATION_DATA 23
|
275
|
+
|
276
|
+
/* Pseudo content type for SSL/TLS header info */
|
277
|
+
#define SSL3_RT_HEADER 0x100
|
278
|
+
|
279
|
+
#define SSL3_AL_WARNING 1
|
280
|
+
#define SSL3_AL_FATAL 2
|
281
|
+
|
282
|
+
#define SSL3_AD_CLOSE_NOTIFY 0
|
283
|
+
#define SSL3_AD_UNEXPECTED_MESSAGE 10 /* fatal */
|
284
|
+
#define SSL3_AD_BAD_RECORD_MAC 20 /* fatal */
|
285
|
+
#define SSL3_AD_DECOMPRESSION_FAILURE 30 /* fatal */
|
286
|
+
#define SSL3_AD_HANDSHAKE_FAILURE 40 /* fatal */
|
287
|
+
#define SSL3_AD_NO_CERTIFICATE 41
|
288
|
+
#define SSL3_AD_BAD_CERTIFICATE 42
|
289
|
+
#define SSL3_AD_UNSUPPORTED_CERTIFICATE 43
|
290
|
+
#define SSL3_AD_CERTIFICATE_REVOKED 44
|
291
|
+
#define SSL3_AD_CERTIFICATE_EXPIRED 45
|
292
|
+
#define SSL3_AD_CERTIFICATE_UNKNOWN 46
|
293
|
+
#define SSL3_AD_ILLEGAL_PARAMETER 47 /* fatal */
|
294
|
+
#define SSL3_AD_INAPPROPRIATE_FALLBACK 86 /* fatal */
|
295
|
+
|
296
|
+
#define SSL3_CT_RSA_SIGN 1
|
297
|
+
#define SSL3_CT_DSS_SIGN 2
|
298
|
+
#define SSL3_CT_RSA_FIXED_DH 3
|
299
|
+
#define SSL3_CT_DSS_FIXED_DH 4
|
300
|
+
#define SSL3_CT_RSA_EPHEMERAL_DH 5
|
301
|
+
#define SSL3_CT_DSS_EPHEMERAL_DH 6
|
302
|
+
#define SSL3_CT_FORTEZZA_DMS 20
|
303
|
+
|
304
|
+
/* SSLv3 */
|
305
|
+
/* client */
|
306
|
+
/* extra state */
|
307
|
+
#define SSL3_ST_CW_FLUSH (0x100 | SSL_ST_CONNECT)
|
308
|
+
#define SSL3_ST_FALSE_START (0x101 | SSL_ST_CONNECT)
|
309
|
+
#define SSL3_ST_VERIFY_SERVER_CERT (0x102 | SSL_ST_CONNECT)
|
310
|
+
/* write to server */
|
311
|
+
#define SSL3_ST_CW_CLNT_HELLO_A (0x110 | SSL_ST_CONNECT)
|
312
|
+
#define SSL3_ST_CW_CLNT_HELLO_B (0x111 | SSL_ST_CONNECT)
|
313
|
+
/* read from server */
|
314
|
+
#define SSL3_ST_CR_SRVR_HELLO_A (0x120 | SSL_ST_CONNECT)
|
315
|
+
#define SSL3_ST_CR_SRVR_HELLO_B (0x121 | SSL_ST_CONNECT)
|
316
|
+
#define DTLS1_ST_CR_HELLO_VERIFY_REQUEST_A (0x126 | SSL_ST_CONNECT)
|
317
|
+
#define DTLS1_ST_CR_HELLO_VERIFY_REQUEST_B (0x127 | SSL_ST_CONNECT)
|
318
|
+
#define SSL3_ST_CR_CERT_A (0x130 | SSL_ST_CONNECT)
|
319
|
+
#define SSL3_ST_CR_CERT_B (0x131 | SSL_ST_CONNECT)
|
320
|
+
#define SSL3_ST_CR_KEY_EXCH_A (0x140 | SSL_ST_CONNECT)
|
321
|
+
#define SSL3_ST_CR_KEY_EXCH_B (0x141 | SSL_ST_CONNECT)
|
322
|
+
#define SSL3_ST_CR_CERT_REQ_A (0x150 | SSL_ST_CONNECT)
|
323
|
+
#define SSL3_ST_CR_CERT_REQ_B (0x151 | SSL_ST_CONNECT)
|
324
|
+
#define SSL3_ST_CR_SRVR_DONE_A (0x160 | SSL_ST_CONNECT)
|
325
|
+
#define SSL3_ST_CR_SRVR_DONE_B (0x161 | SSL_ST_CONNECT)
|
326
|
+
/* write to server */
|
327
|
+
#define SSL3_ST_CW_CERT_A (0x170 | SSL_ST_CONNECT)
|
328
|
+
#define SSL3_ST_CW_CERT_B (0x171 | SSL_ST_CONNECT)
|
329
|
+
#define SSL3_ST_CW_CERT_C (0x172 | SSL_ST_CONNECT)
|
330
|
+
#define SSL3_ST_CW_CERT_D (0x173 | SSL_ST_CONNECT)
|
331
|
+
#define SSL3_ST_CW_KEY_EXCH_A (0x180 | SSL_ST_CONNECT)
|
332
|
+
#define SSL3_ST_CW_KEY_EXCH_B (0x181 | SSL_ST_CONNECT)
|
333
|
+
#define SSL3_ST_CW_CERT_VRFY_A (0x190 | SSL_ST_CONNECT)
|
334
|
+
#define SSL3_ST_CW_CERT_VRFY_B (0x191 | SSL_ST_CONNECT)
|
335
|
+
#define SSL3_ST_CW_CERT_VRFY_C (0x192 | SSL_ST_CONNECT)
|
336
|
+
#define SSL3_ST_CW_CHANGE_A (0x1A0 | SSL_ST_CONNECT)
|
337
|
+
#define SSL3_ST_CW_CHANGE_B (0x1A1 | SSL_ST_CONNECT)
|
338
|
+
#define SSL3_ST_CW_NEXT_PROTO_A (0x200 | SSL_ST_CONNECT)
|
339
|
+
#define SSL3_ST_CW_NEXT_PROTO_B (0x201 | SSL_ST_CONNECT)
|
340
|
+
#define SSL3_ST_CW_CHANNEL_ID_A (0x220 | SSL_ST_CONNECT)
|
341
|
+
#define SSL3_ST_CW_CHANNEL_ID_B (0x221 | SSL_ST_CONNECT)
|
342
|
+
#define SSL3_ST_CW_FINISHED_A (0x1B0 | SSL_ST_CONNECT)
|
343
|
+
#define SSL3_ST_CW_FINISHED_B (0x1B1 | SSL_ST_CONNECT)
|
344
|
+
/* read from server */
|
345
|
+
#define SSL3_ST_CR_CHANGE (0x1C0 | SSL_ST_CONNECT)
|
346
|
+
#define SSL3_ST_CR_FINISHED_A (0x1D0 | SSL_ST_CONNECT)
|
347
|
+
#define SSL3_ST_CR_FINISHED_B (0x1D1 | SSL_ST_CONNECT)
|
348
|
+
#define SSL3_ST_CR_SESSION_TICKET_A (0x1E0 | SSL_ST_CONNECT)
|
349
|
+
#define SSL3_ST_CR_SESSION_TICKET_B (0x1E1 | SSL_ST_CONNECT)
|
350
|
+
#define SSL3_ST_CR_CERT_STATUS_A (0x1F0 | SSL_ST_CONNECT)
|
351
|
+
#define SSL3_ST_CR_CERT_STATUS_B (0x1F1 | SSL_ST_CONNECT)
|
352
|
+
|
353
|
+
/* server */
|
354
|
+
/* extra state */
|
355
|
+
#define SSL3_ST_SW_FLUSH (0x100 | SSL_ST_ACCEPT)
|
356
|
+
/* read from client */
|
357
|
+
#define SSL3_ST_SR_INITIAL_BYTES (0x240 | SSL_ST_ACCEPT)
|
358
|
+
#define SSL3_ST_SR_V2_CLIENT_HELLO (0x241 | SSL_ST_ACCEPT)
|
359
|
+
#define SSL3_ST_SR_CLNT_HELLO_A (0x110 | SSL_ST_ACCEPT)
|
360
|
+
#define SSL3_ST_SR_CLNT_HELLO_B (0x111 | SSL_ST_ACCEPT)
|
361
|
+
#define SSL3_ST_SR_CLNT_HELLO_C (0x112 | SSL_ST_ACCEPT)
|
362
|
+
#define SSL3_ST_SR_CLNT_HELLO_D (0x115 | SSL_ST_ACCEPT)
|
363
|
+
/* write to client */
|
364
|
+
#define SSL3_ST_SW_HELLO_REQ_A (0x120 | SSL_ST_ACCEPT)
|
365
|
+
#define SSL3_ST_SW_HELLO_REQ_B (0x121 | SSL_ST_ACCEPT)
|
366
|
+
#define SSL3_ST_SW_HELLO_REQ_C (0x122 | SSL_ST_ACCEPT)
|
367
|
+
#define SSL3_ST_SW_SRVR_HELLO_A (0x130 | SSL_ST_ACCEPT)
|
368
|
+
#define SSL3_ST_SW_SRVR_HELLO_B (0x131 | SSL_ST_ACCEPT)
|
369
|
+
#define SSL3_ST_SW_CERT_A (0x140 | SSL_ST_ACCEPT)
|
370
|
+
#define SSL3_ST_SW_CERT_B (0x141 | SSL_ST_ACCEPT)
|
371
|
+
#define SSL3_ST_SW_KEY_EXCH_A (0x150 | SSL_ST_ACCEPT)
|
372
|
+
#define SSL3_ST_SW_KEY_EXCH_B (0x151 | SSL_ST_ACCEPT)
|
373
|
+
#define SSL3_ST_SW_KEY_EXCH_C (0x152 | SSL_ST_ACCEPT)
|
374
|
+
#define SSL3_ST_SW_CERT_REQ_A (0x160 | SSL_ST_ACCEPT)
|
375
|
+
#define SSL3_ST_SW_CERT_REQ_B (0x161 | SSL_ST_ACCEPT)
|
376
|
+
#define SSL3_ST_SW_SRVR_DONE_A (0x170 | SSL_ST_ACCEPT)
|
377
|
+
#define SSL3_ST_SW_SRVR_DONE_B (0x171 | SSL_ST_ACCEPT)
|
378
|
+
/* read from client */
|
379
|
+
#define SSL3_ST_SR_CERT_A (0x180 | SSL_ST_ACCEPT)
|
380
|
+
#define SSL3_ST_SR_CERT_B (0x181 | SSL_ST_ACCEPT)
|
381
|
+
#define SSL3_ST_SR_KEY_EXCH_A (0x190 | SSL_ST_ACCEPT)
|
382
|
+
#define SSL3_ST_SR_KEY_EXCH_B (0x191 | SSL_ST_ACCEPT)
|
383
|
+
#define SSL3_ST_SR_KEY_EXCH_C (0x192 | SSL_ST_ACCEPT)
|
384
|
+
#define SSL3_ST_SR_CERT_VRFY_A (0x1A0 | SSL_ST_ACCEPT)
|
385
|
+
#define SSL3_ST_SR_CERT_VRFY_B (0x1A1 | SSL_ST_ACCEPT)
|
386
|
+
#define SSL3_ST_SR_CHANGE (0x1B0 | SSL_ST_ACCEPT)
|
387
|
+
#define SSL3_ST_SR_NEXT_PROTO_A (0x210 | SSL_ST_ACCEPT)
|
388
|
+
#define SSL3_ST_SR_NEXT_PROTO_B (0x211 | SSL_ST_ACCEPT)
|
389
|
+
#define SSL3_ST_SR_CHANNEL_ID_A (0x230 | SSL_ST_ACCEPT)
|
390
|
+
#define SSL3_ST_SR_CHANNEL_ID_B (0x231 | SSL_ST_ACCEPT)
|
391
|
+
#define SSL3_ST_SR_FINISHED_A (0x1C0 | SSL_ST_ACCEPT)
|
392
|
+
#define SSL3_ST_SR_FINISHED_B (0x1C1 | SSL_ST_ACCEPT)
|
393
|
+
|
394
|
+
/* write to client */
|
395
|
+
#define SSL3_ST_SW_CHANGE_A (0x1D0 | SSL_ST_ACCEPT)
|
396
|
+
#define SSL3_ST_SW_CHANGE_B (0x1D1 | SSL_ST_ACCEPT)
|
397
|
+
#define SSL3_ST_SW_FINISHED_A (0x1E0 | SSL_ST_ACCEPT)
|
398
|
+
#define SSL3_ST_SW_FINISHED_B (0x1E1 | SSL_ST_ACCEPT)
|
399
|
+
#define SSL3_ST_SW_SESSION_TICKET_A (0x1F0 | SSL_ST_ACCEPT)
|
400
|
+
#define SSL3_ST_SW_SESSION_TICKET_B (0x1F1 | SSL_ST_ACCEPT)
|
401
|
+
#define SSL3_ST_SW_CERT_STATUS_A (0x200 | SSL_ST_ACCEPT)
|
402
|
+
#define SSL3_ST_SW_CERT_STATUS_B (0x201 | SSL_ST_ACCEPT)
|
403
|
+
#define SSL3_ST_SW_SUPPLEMENTAL_DATA_A (0x220 | SSL_ST_ACCEPT)
|
404
|
+
#define SSL3_ST_SW_SUPPLEMENTAL_DATA_B (0x221 | SSL_ST_ACCEPT)
|
405
|
+
|
406
|
+
#define SSL3_MT_HELLO_REQUEST 0
|
407
|
+
#define SSL3_MT_CLIENT_HELLO 1
|
408
|
+
#define SSL3_MT_SERVER_HELLO 2
|
409
|
+
#define SSL3_MT_NEWSESSION_TICKET 4
|
410
|
+
#define SSL3_MT_CERTIFICATE 11
|
411
|
+
#define SSL3_MT_SERVER_KEY_EXCHANGE 12
|
412
|
+
#define SSL3_MT_CERTIFICATE_REQUEST 13
|
413
|
+
#define SSL3_MT_SERVER_DONE 14
|
414
|
+
#define SSL3_MT_CERTIFICATE_VERIFY 15
|
415
|
+
#define SSL3_MT_CLIENT_KEY_EXCHANGE 16
|
416
|
+
#define SSL3_MT_FINISHED 20
|
417
|
+
#define SSL3_MT_CERTIFICATE_STATUS 22
|
418
|
+
#define SSL3_MT_SUPPLEMENTAL_DATA 23
|
419
|
+
#define SSL3_MT_NEXT_PROTO 67
|
420
|
+
#define SSL3_MT_ENCRYPTED_EXTENSIONS 203
|
421
|
+
#define DTLS1_MT_HELLO_VERIFY_REQUEST 3
|
422
|
+
|
423
|
+
|
424
|
+
#define SSL3_MT_CCS 1
|
425
|
+
|
426
|
+
/* These are used when changing over to a new cipher */
|
427
|
+
#define SSL3_CC_READ 0x01
|
428
|
+
#define SSL3_CC_WRITE 0x02
|
429
|
+
#define SSL3_CC_CLIENT 0x10
|
430
|
+
#define SSL3_CC_SERVER 0x20
|
431
|
+
#define SSL3_CHANGE_CIPHER_CLIENT_WRITE (SSL3_CC_CLIENT | SSL3_CC_WRITE)
|
432
|
+
#define SSL3_CHANGE_CIPHER_SERVER_READ (SSL3_CC_SERVER | SSL3_CC_READ)
|
433
|
+
#define SSL3_CHANGE_CIPHER_CLIENT_READ (SSL3_CC_CLIENT | SSL3_CC_READ)
|
434
|
+
#define SSL3_CHANGE_CIPHER_SERVER_WRITE (SSL3_CC_SERVER | SSL3_CC_WRITE)
|
435
|
+
|
436
|
+
|
437
|
+
#ifdef __cplusplus
|
438
|
+
} /* extern C */
|
439
|
+
#endif
|
440
|
+
|
441
|
+
#endif /* OPENSSL_HEADER_SSL3_H */
|
@@ -0,0 +1,298 @@
|
|
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
|
+
#ifndef OPENSSL_HEADER_STACK_H
|
58
|
+
#define OPENSSL_HEADER_STACK_H
|
59
|
+
|
60
|
+
#include <openssl/base.h>
|
61
|
+
|
62
|
+
#include <openssl/type_check.h>
|
63
|
+
|
64
|
+
#if defined(__cplusplus)
|
65
|
+
extern "C" {
|
66
|
+
#endif
|
67
|
+
|
68
|
+
|
69
|
+
/* A stack, in OpenSSL, is an array of pointers. They are the most commonly
|
70
|
+
* used collection object.
|
71
|
+
*
|
72
|
+
* This file defines macros for type safe use of the stack functions. A stack
|
73
|
+
* of a specific type of object has type |STACK_OF(type)|. This can be defined
|
74
|
+
* (once) with |DEFINE_STACK_OF(type)| and declared where needed with
|
75
|
+
* |DECLARE_STACK_OF(type)|. For example:
|
76
|
+
*
|
77
|
+
* struct foo {
|
78
|
+
* int bar;
|
79
|
+
* };
|
80
|
+
*
|
81
|
+
* DEFINE_STACK_OF(struct foo);
|
82
|
+
*
|
83
|
+
* Although note that the stack will contain /pointers/ to |foo|.
|
84
|
+
*
|
85
|
+
* A macro will be defined for each of the sk_* functions below. For
|
86
|
+
* STACK_OF(foo), the macros would be sk_foo_new, sk_foo_pop etc. */
|
87
|
+
|
88
|
+
|
89
|
+
/* stack_cmp_func is a comparison function that returns a value < 0, 0 or > 0
|
90
|
+
* if |*a| is less than, equal to or greater than |*b|, respectively. Note the
|
91
|
+
* extra indirection - the function is given a pointer to a pointer to the
|
92
|
+
* element. This differs from the usual qsort/bsearch comparison function. */
|
93
|
+
typedef int (*stack_cmp_func)(const void **a, const void **b);
|
94
|
+
|
95
|
+
/* stack_st contains an array of pointers. It is not designed to be used
|
96
|
+
* directly, rather the wrapper macros should be used. */
|
97
|
+
typedef struct stack_st {
|
98
|
+
/* num contains the number of valid pointers in |data|. */
|
99
|
+
size_t num;
|
100
|
+
void **data;
|
101
|
+
/* sorted is non-zero if the values pointed to by |data| are in ascending
|
102
|
+
* order, based on |comp|. */
|
103
|
+
size_t sorted;
|
104
|
+
/* num_alloc contains the number of pointers allocated in the buffer pointed
|
105
|
+
* to by |data|, which may be larger than |num|. */
|
106
|
+
size_t num_alloc;
|
107
|
+
/* comp is an optional comparison function. */
|
108
|
+
stack_cmp_func comp;
|
109
|
+
} _STACK;
|
110
|
+
|
111
|
+
|
112
|
+
#define STACK_OF(type) struct stack_st_##type
|
113
|
+
|
114
|
+
#define DECLARE_STACK_OF(type) STACK_OF(type);
|
115
|
+
|
116
|
+
/* The make_macros.sh script in this directory parses the following lines and
|
117
|
+
* generates the stack_macros.h file that contains macros for the following
|
118
|
+
* types of stacks:
|
119
|
+
*
|
120
|
+
* STACK_OF:ACCESS_DESCRIPTION
|
121
|
+
* STACK_OF:ASN1_ADB_TABLE
|
122
|
+
* STACK_OF:ASN1_GENERALSTRING
|
123
|
+
* STACK_OF:ASN1_INTEGER
|
124
|
+
* STACK_OF:ASN1_OBJECT
|
125
|
+
* STACK_OF:ASN1_STRING_TABLE
|
126
|
+
* STACK_OF:ASN1_TYPE
|
127
|
+
* STACK_OF:ASN1_VALUE
|
128
|
+
* STACK_OF:BIO
|
129
|
+
* STACK_OF:BY_DIR_ENTRY
|
130
|
+
* STACK_OF:BY_DIR_HASH
|
131
|
+
* STACK_OF:CONF_VALUE
|
132
|
+
* STACK_OF:CRYPTO_EX_DATA_FUNCS
|
133
|
+
* STACK_OF:DIST_POINT
|
134
|
+
* STACK_OF:GENERAL_NAME
|
135
|
+
* STACK_OF:GENERAL_NAMES
|
136
|
+
* STACK_OF:GENERAL_SUBTREE
|
137
|
+
* STACK_OF:MIME_HEADER
|
138
|
+
* STACK_OF:PKCS7_RECIP_INFO
|
139
|
+
* STACK_OF:PKCS7_SIGNER_INFO
|
140
|
+
* STACK_OF:POLICYINFO
|
141
|
+
* STACK_OF:POLICYQUALINFO
|
142
|
+
* STACK_OF:POLICY_MAPPING
|
143
|
+
* STACK_OF:RSA_additional_prime
|
144
|
+
* STACK_OF:SSL_COMP
|
145
|
+
* STACK_OF:SSL_CUSTOM_EXTENSION
|
146
|
+
* STACK_OF:STACK_OF_X509_NAME_ENTRY
|
147
|
+
* STACK_OF:SXNETID
|
148
|
+
* STACK_OF:X509
|
149
|
+
* STACK_OF:X509V3_EXT_METHOD
|
150
|
+
* STACK_OF:X509_ALGOR
|
151
|
+
* STACK_OF:X509_ATTRIBUTE
|
152
|
+
* STACK_OF:X509_CRL
|
153
|
+
* STACK_OF:X509_EXTENSION
|
154
|
+
* STACK_OF:X509_INFO
|
155
|
+
* STACK_OF:X509_LOOKUP
|
156
|
+
* STACK_OF:X509_NAME
|
157
|
+
* STACK_OF:X509_NAME_ENTRY
|
158
|
+
* STACK_OF:X509_OBJECT
|
159
|
+
* STACK_OF:X509_POLICY_DATA
|
160
|
+
* STACK_OF:X509_POLICY_NODE
|
161
|
+
* STACK_OF:X509_PURPOSE
|
162
|
+
* STACK_OF:X509_REVOKED
|
163
|
+
* STACK_OF:X509_TRUST
|
164
|
+
* STACK_OF:X509_VERIFY_PARAM
|
165
|
+
* STACK_OF:void
|
166
|
+
*
|
167
|
+
* Some stacks contain only const structures, so the stack should return const
|
168
|
+
* pointers to retain type-checking.
|
169
|
+
*
|
170
|
+
* CONST_STACK_OF:SRTP_PROTECTION_PROFILE
|
171
|
+
* CONST_STACK_OF:SSL_CIPHER */
|
172
|
+
|
173
|
+
|
174
|
+
/* Some stacks are special because, although we would like STACK_OF(char *),
|
175
|
+
* that would actually be a stack of pointers to char*, but we just want to
|
176
|
+
* point to the string directly. In this case we call them "special" and use
|
177
|
+
* |DEFINE_SPECIAL_STACK_OF(type)| */
|
178
|
+
#define DEFINE_SPECIAL_STACK_OF(type, inner) \
|
179
|
+
STACK_OF(type) { _STACK special_stack; }; \
|
180
|
+
OPENSSL_COMPILE_ASSERT(sizeof(type) == sizeof(void *), \
|
181
|
+
special_stack_of_non_pointer_##type);
|
182
|
+
|
183
|
+
typedef char *OPENSSL_STRING;
|
184
|
+
|
185
|
+
DEFINE_SPECIAL_STACK_OF(OPENSSL_STRING, char)
|
186
|
+
DEFINE_SPECIAL_STACK_OF(OPENSSL_BLOCK, uint8_t)
|
187
|
+
|
188
|
+
/* The make_macros.sh script in this directory parses the following lines and
|
189
|
+
* generates the stack_macros.h file that contains macros for the following
|
190
|
+
* types of stacks:
|
191
|
+
*
|
192
|
+
* SPECIAL_STACK_OF:OPENSSL_STRING
|
193
|
+
* SPECIAL_STACK_OF:OPENSSL_BLOCK */
|
194
|
+
|
195
|
+
#define IN_STACK_H
|
196
|
+
#include <openssl/stack_macros.h>
|
197
|
+
#undef IN_STACK_H
|
198
|
+
|
199
|
+
|
200
|
+
/* These are the raw stack functions, you shouldn't be using them. Rather you
|
201
|
+
* should be using the type stack macros implemented above. */
|
202
|
+
|
203
|
+
/* sk_new creates a new, empty stack with the given comparison function, which
|
204
|
+
* may be zero. It returns the new stack or NULL on allocation failure. */
|
205
|
+
OPENSSL_EXPORT _STACK *sk_new(stack_cmp_func comp);
|
206
|
+
|
207
|
+
/* sk_new_null creates a new, empty stack. It returns the new stack or NULL on
|
208
|
+
* allocation failure. */
|
209
|
+
OPENSSL_EXPORT _STACK *sk_new_null(void);
|
210
|
+
|
211
|
+
/* sk_num returns the number of elements in |s|. */
|
212
|
+
OPENSSL_EXPORT size_t sk_num(const _STACK *sk);
|
213
|
+
|
214
|
+
/* sk_zero resets |sk| to the empty state but does nothing to free the
|
215
|
+
* individual elements themselves. */
|
216
|
+
OPENSSL_EXPORT void sk_zero(_STACK *sk);
|
217
|
+
|
218
|
+
/* sk_value returns the |i|th pointer in |sk|, or NULL if |i| is out of
|
219
|
+
* range. */
|
220
|
+
OPENSSL_EXPORT void *sk_value(const _STACK *sk, size_t i);
|
221
|
+
|
222
|
+
/* sk_set sets the |i|th pointer in |sk| to |p| and returns |p|. If |i| is out
|
223
|
+
* of range, it returns NULL. */
|
224
|
+
OPENSSL_EXPORT void *sk_set(_STACK *sk, size_t i, void *p);
|
225
|
+
|
226
|
+
/* sk_free frees the given stack and array of pointers, but does nothing to
|
227
|
+
* free the individual elements. Also see |sk_pop_free|. */
|
228
|
+
OPENSSL_EXPORT void sk_free(_STACK *sk);
|
229
|
+
|
230
|
+
/* sk_pop_free calls |free_func| on each element in the stack and then frees
|
231
|
+
* the stack itself. */
|
232
|
+
OPENSSL_EXPORT void sk_pop_free(_STACK *sk, void (*free_func)(void *));
|
233
|
+
|
234
|
+
/* sk_insert inserts |p| into the stack at index |where|, moving existing
|
235
|
+
* elements if needed. It returns the length of the new stack, or zero on
|
236
|
+
* error. */
|
237
|
+
OPENSSL_EXPORT size_t sk_insert(_STACK *sk, void *p, size_t where);
|
238
|
+
|
239
|
+
/* sk_delete removes the pointer at index |where|, moving other elements down
|
240
|
+
* if needed. It returns the removed pointer, or NULL if |where| is out of
|
241
|
+
* range. */
|
242
|
+
OPENSSL_EXPORT void *sk_delete(_STACK *sk, size_t where);
|
243
|
+
|
244
|
+
/* sk_delete_ptr removes, at most, one instance of |p| from the stack based on
|
245
|
+
* pointer equality. If an instance of |p| is found then |p| is returned,
|
246
|
+
* otherwise it returns NULL. */
|
247
|
+
OPENSSL_EXPORT void *sk_delete_ptr(_STACK *sk, void *p);
|
248
|
+
|
249
|
+
/* sk_find returns the first value in the stack equal to |p|. If a comparison
|
250
|
+
* function has been set on the stack, then equality is defined by it and the
|
251
|
+
* stack will be sorted if need be so that a binary search can be used.
|
252
|
+
* Otherwise pointer equality is used. If a matching element is found, its
|
253
|
+
* index is written to |*out_index| (if |out_index| is not NULL) and one is
|
254
|
+
* returned. Otherwise zero is returned. */
|
255
|
+
OPENSSL_EXPORT int sk_find(_STACK *sk, size_t *out_index, void *p);
|
256
|
+
|
257
|
+
/* sk_shift removes and returns the first element in the stack, or returns NULL
|
258
|
+
* if the stack is empty. */
|
259
|
+
OPENSSL_EXPORT void *sk_shift(_STACK *sk);
|
260
|
+
|
261
|
+
/* sk_push appends |p| to the stack and returns the length of the new stack, or
|
262
|
+
* 0 on allocation failure. */
|
263
|
+
OPENSSL_EXPORT size_t sk_push(_STACK *sk, void *p);
|
264
|
+
|
265
|
+
/* sk_pop returns and removes the last element on the stack, or NULL if the
|
266
|
+
* stack is empty. */
|
267
|
+
OPENSSL_EXPORT void *sk_pop(_STACK *sk);
|
268
|
+
|
269
|
+
/* sk_dup performs a shallow copy of a stack and returns the new stack, or NULL
|
270
|
+
* on error. */
|
271
|
+
OPENSSL_EXPORT _STACK *sk_dup(const _STACK *sk);
|
272
|
+
|
273
|
+
/* sk_sort sorts the elements of |sk| into ascending order based on the
|
274
|
+
* comparison function. The stack maintains a |sorted| flag and sorting an
|
275
|
+
* already sorted stack is a no-op. */
|
276
|
+
OPENSSL_EXPORT void sk_sort(_STACK *sk);
|
277
|
+
|
278
|
+
/* sk_is_sorted returns one if |sk| is known to be sorted and zero
|
279
|
+
* otherwise. */
|
280
|
+
OPENSSL_EXPORT int sk_is_sorted(const _STACK *sk);
|
281
|
+
|
282
|
+
/* sk_set_cmp_func sets the comparison function to be used by |sk| and returns
|
283
|
+
* the previous one. */
|
284
|
+
OPENSSL_EXPORT stack_cmp_func sk_set_cmp_func(_STACK *sk, stack_cmp_func comp);
|
285
|
+
|
286
|
+
/* sk_deep_copy performs a copy of |sk| and of each of the non-NULL elements in
|
287
|
+
* |sk| by using |copy_func|. If an error occurs, |free_func| is used to free
|
288
|
+
* any copies already made and NULL is returned. */
|
289
|
+
OPENSSL_EXPORT _STACK *sk_deep_copy(const _STACK *sk,
|
290
|
+
void *(*copy_func)(void *),
|
291
|
+
void (*free_func)(void *));
|
292
|
+
|
293
|
+
|
294
|
+
#if defined(__cplusplus)
|
295
|
+
} /* extern C */
|
296
|
+
#endif
|
297
|
+
|
298
|
+
#endif /* OPENSSL_HEADER_STACK_H */
|