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.

Files changed (673) hide show
  1. checksums.yaml +4 -4
  2. data/Makefile +5707 -22222
  3. data/include/grpc/byte_buffer.h +2 -83
  4. data/include/grpc/census.h +191 -121
  5. data/include/grpc/compression.h +14 -38
  6. data/include/grpc/grpc.h +88 -434
  7. data/include/grpc/grpc_security.h +76 -46
  8. data/include/grpc/grpc_zookeeper.h +1 -1
  9. data/include/grpc/impl/codegen/alloc.h +74 -0
  10. data/include/grpc/impl/codegen/atm.h +92 -0
  11. data/include/grpc/impl/codegen/atm_gcc_atomic.h +72 -0
  12. data/include/grpc/impl/codegen/atm_gcc_sync.h +87 -0
  13. data/include/grpc/impl/codegen/atm_win32.h +125 -0
  14. data/include/grpc/impl/codegen/byte_buffer.h +121 -0
  15. data/include/grpc/impl/codegen/compression_types.h +73 -0
  16. data/include/grpc/impl/codegen/connectivity_state.h +59 -0
  17. data/include/grpc/impl/codegen/grpc_types.h +373 -0
  18. data/include/grpc/impl/codegen/log.h +110 -0
  19. data/include/grpc/impl/codegen/port_platform.h +362 -0
  20. data/include/grpc/impl/codegen/propagation_bits.h +67 -0
  21. data/include/grpc/impl/codegen/slice.h +182 -0
  22. data/include/grpc/impl/codegen/slice_buffer.h +105 -0
  23. data/include/grpc/impl/codegen/status.h +163 -0
  24. data/include/grpc/impl/codegen/sync.h +316 -0
  25. data/include/grpc/impl/codegen/sync_generic.h +55 -0
  26. data/{src/core/census/context.h → include/grpc/impl/codegen/sync_posix.h} +11 -11
  27. data/include/grpc/impl/codegen/sync_win32.h +49 -0
  28. data/include/grpc/impl/codegen/time.h +132 -0
  29. data/include/grpc/status.h +2 -126
  30. data/include/grpc/support/alloc.h +2 -35
  31. data/include/grpc/support/atm.h +2 -55
  32. data/include/grpc/support/atm_gcc_atomic.h +5 -38
  33. data/include/grpc/support/atm_gcc_sync.h +2 -50
  34. data/include/grpc/support/atm_win32.h +2 -88
  35. data/include/grpc/support/avl.h +7 -7
  36. data/include/grpc/support/cmdline.h +15 -13
  37. data/include/grpc/support/cpu.h +5 -3
  38. data/include/grpc/support/histogram.h +23 -20
  39. data/include/grpc/support/host_port.h +5 -3
  40. data/include/grpc/support/log.h +2 -71
  41. data/include/grpc/support/log_win32.h +2 -2
  42. data/include/grpc/support/port_platform.h +2 -319
  43. data/include/grpc/support/slice.h +2 -145
  44. data/include/grpc/support/slice_buffer.h +2 -65
  45. data/include/grpc/support/string_util.h +3 -3
  46. data/include/grpc/support/subprocess.h +8 -6
  47. data/include/grpc/support/sync.h +2 -278
  48. data/include/grpc/support/sync_generic.h +2 -18
  49. data/include/grpc/support/sync_posix.h +2 -10
  50. data/include/grpc/support/sync_win32.h +2 -12
  51. data/include/grpc/support/thd.h +11 -11
  52. data/include/grpc/support/time.h +2 -91
  53. data/include/grpc/support/tls.h +1 -1
  54. data/include/grpc/support/tls_gcc.h +1 -1
  55. data/include/grpc/support/tls_msvc.h +1 -1
  56. data/include/grpc/support/tls_pthread.h +2 -2
  57. data/src/boringssl/err_data.c +1252 -0
  58. data/src/core/census/context.c +492 -8
  59. data/src/core/census/grpc_filter.c +3 -3
  60. data/src/core/census/initialize.c +4 -7
  61. data/src/core/census/operation.c +2 -2
  62. data/src/core/census/placeholders.c +109 -0
  63. data/src/core/census/rpc_metric_id.h +6 -6
  64. data/src/core/census/tracing.c +1 -1
  65. data/src/core/channel/channel_args.c +4 -3
  66. data/src/core/channel/channel_stack.c +1 -1
  67. data/src/core/channel/client_channel.c +18 -14
  68. data/src/core/channel/client_uchannel.c +3 -3
  69. data/src/core/channel/compress_filter.c +8 -8
  70. data/src/core/channel/http_client_filter.c +2 -2
  71. data/src/core/channel/http_server_filter.c +9 -9
  72. data/src/core/channel/subchannel_call_holder.c +12 -10
  73. data/src/core/client_config/lb_policies/pick_first.c +49 -31
  74. data/src/core/client_config/lb_policies/round_robin.c +7 -7
  75. data/src/core/client_config/resolvers/dns_resolver.c +3 -3
  76. data/src/core/client_config/resolvers/sockaddr_resolver.c +5 -5
  77. data/src/core/client_config/subchannel.c +36 -25
  78. data/src/core/compression/algorithm.c +3 -3
  79. data/src/core/httpcli/format_request.c +1 -1
  80. data/src/core/httpcli/httpcli.c +5 -5
  81. data/src/core/httpcli/httpcli_security_connector.c +2 -3
  82. data/src/core/httpcli/parser.c +7 -7
  83. data/src/core/httpcli/parser.h +1 -1
  84. data/src/core/iomgr/closure.c +7 -7
  85. data/src/core/iomgr/closure.h +6 -5
  86. data/src/core/iomgr/exec_ctx.c +12 -8
  87. data/src/core/iomgr/exec_ctx.h +12 -5
  88. data/src/core/iomgr/executor.c +4 -4
  89. data/src/core/iomgr/executor.h +2 -2
  90. data/src/core/iomgr/fd_posix.c +28 -17
  91. data/src/core/iomgr/fd_posix.h +7 -4
  92. data/src/core/iomgr/iocp_windows.c +6 -8
  93. data/src/core/iomgr/pollset_multipoller_with_epoll.c +70 -5
  94. data/src/core/iomgr/pollset_multipoller_with_poll_posix.c +4 -2
  95. data/src/core/iomgr/pollset_posix.c +15 -15
  96. data/src/core/iomgr/pollset_posix.h +4 -2
  97. data/src/core/iomgr/pollset_windows.c +3 -12
  98. data/src/core/iomgr/resolve_address_posix.c +2 -2
  99. data/src/core/iomgr/resolve_address_windows.c +2 -2
  100. data/src/core/iomgr/sockaddr_utils.c +6 -6
  101. data/src/core/iomgr/sockaddr_win32.h +1 -6
  102. data/src/core/iomgr/tcp_client_posix.c +7 -7
  103. data/src/core/iomgr/tcp_client_windows.c +4 -4
  104. data/src/core/iomgr/tcp_posix.c +14 -8
  105. data/src/core/iomgr/tcp_posix.h +7 -1
  106. data/src/core/iomgr/tcp_server.h +40 -20
  107. data/src/core/iomgr/tcp_server_posix.c +106 -49
  108. data/src/core/iomgr/tcp_server_windows.c +98 -49
  109. data/src/core/iomgr/tcp_windows.c +11 -15
  110. data/src/core/iomgr/timer.c +8 -8
  111. data/src/core/iomgr/timer.h +1 -1
  112. data/src/core/iomgr/timer_heap.c +10 -10
  113. data/src/core/iomgr/timer_heap.h +2 -2
  114. data/src/core/iomgr/udp_server.c +2 -12
  115. data/src/core/iomgr/udp_server.h +1 -9
  116. data/src/core/iomgr/workqueue.h +2 -4
  117. data/src/core/iomgr/workqueue_posix.c +3 -3
  118. data/src/core/json/json_reader.c +11 -12
  119. data/src/core/json/json_reader.h +4 -4
  120. data/src/core/json/json_string.c +19 -19
  121. data/src/core/json/json_writer.c +7 -9
  122. data/src/core/profiling/basic_timers.c +1 -1
  123. data/src/core/security/base64.c +9 -9
  124. data/src/core/security/client_auth_filter.c +4 -4
  125. data/src/core/security/credentials.c +5 -5
  126. data/src/core/security/google_default_credentials.c +3 -3
  127. data/src/core/security/handshake.c +6 -5
  128. data/src/core/security/json_token.c +13 -7
  129. data/src/core/security/jwt_verifier.c +3 -2
  130. data/src/core/security/secure_endpoint.c +16 -16
  131. data/src/core/security/security_connector.c +47 -17
  132. data/src/core/security/security_connector.h +5 -5
  133. data/src/core/security/server_auth_filter.c +3 -3
  134. data/src/core/security/server_secure_chttp2.c +30 -31
  135. data/src/core/statistics/census_interface.h +2 -2
  136. data/src/core/statistics/census_rpc_stats.h +3 -3
  137. data/src/core/support/alloc.c +1 -1
  138. data/src/core/support/cpu_posix.c +2 -2
  139. data/src/core/support/env_linux.c +12 -2
  140. data/src/core/support/env_win32.c +15 -7
  141. data/src/core/support/histogram.c +5 -5
  142. data/src/core/support/log_posix.c +1 -1
  143. data/src/core/support/log_win32.c +4 -3
  144. data/src/core/support/murmur_hash.c +11 -11
  145. data/src/core/support/murmur_hash.h +1 -1
  146. data/src/core/support/slice.c +11 -11
  147. data/src/core/support/slice_buffer.c +6 -6
  148. data/src/core/support/stack_lockfree.c +20 -10
  149. data/src/core/support/string.c +15 -15
  150. data/src/core/support/string.h +5 -5
  151. data/src/core/support/string_win32.c +5 -5
  152. data/src/core/support/subprocess_windows.c +141 -0
  153. data/src/core/support/sync.c +4 -4
  154. data/src/core/support/sync_posix.c +2 -2
  155. data/src/core/support/sync_win32.c +10 -5
  156. data/src/core/support/time.c +29 -29
  157. data/src/core/support/time_posix.c +15 -6
  158. data/src/core/support/time_precise.c +2 -2
  159. data/src/core/support/time_win32.c +18 -9
  160. data/src/core/support/tls_pthread.c +1 -1
  161. data/src/core/support/wrap_memcpy.c +53 -0
  162. data/src/core/surface/alarm.c +83 -0
  163. data/src/core/surface/byte_buffer_reader.c +1 -1
  164. data/src/core/surface/call.c +78 -69
  165. data/src/core/surface/call.h +2 -2
  166. data/src/core/surface/call_test_only.h +2 -2
  167. data/src/core/surface/channel.c +9 -9
  168. data/src/core/surface/channel.h +1 -1
  169. data/src/core/surface/channel_connectivity.c +3 -3
  170. data/src/core/surface/channel_create.c +3 -3
  171. data/src/core/surface/channel_ping.c +2 -2
  172. data/src/core/surface/completion_queue.c +11 -12
  173. data/src/core/surface/completion_queue.h +1 -1
  174. data/src/core/surface/init.c +7 -5
  175. data/src/core/surface/lame_client.c +3 -3
  176. data/src/core/surface/secure_channel_create.c +3 -3
  177. data/src/core/surface/server.c +28 -28
  178. data/src/core/surface/server_chttp2.c +8 -8
  179. data/src/core/surface/server_create.c +1 -4
  180. data/src/core/surface/validate_metadata.c +3 -3
  181. data/src/core/surface/version.c +2 -2
  182. data/src/core/transport/byte_stream.c +8 -6
  183. data/src/core/transport/byte_stream.h +6 -5
  184. data/src/core/transport/chttp2/bin_encoder.c +29 -29
  185. data/src/core/transport/chttp2/frame_data.c +29 -26
  186. data/src/core/transport/chttp2/frame_data.h +6 -6
  187. data/src/core/transport/chttp2/frame_goaway.c +30 -30
  188. data/src/core/transport/chttp2/frame_goaway.h +6 -6
  189. data/src/core/transport/chttp2/frame_ping.c +6 -6
  190. data/src/core/transport/chttp2/frame_ping.h +5 -5
  191. data/src/core/transport/chttp2/frame_rst_stream.c +18 -19
  192. data/src/core/transport/chttp2/frame_rst_stream.h +4 -4
  193. data/src/core/transport/chttp2/frame_settings.c +30 -30
  194. data/src/core/transport/chttp2/frame_settings.h +13 -13
  195. data/src/core/transport/chttp2/frame_window_update.c +17 -18
  196. data/src/core/transport/chttp2/frame_window_update.h +5 -7
  197. data/src/core/transport/chttp2/hpack_encoder.c +69 -73
  198. data/src/core/transport/chttp2/hpack_encoder.h +16 -16
  199. data/src/core/transport/chttp2/hpack_parser.c +167 -167
  200. data/src/core/transport/chttp2/hpack_parser.h +16 -16
  201. data/src/core/transport/chttp2/hpack_table.c +13 -13
  202. data/src/core/transport/chttp2/hpack_table.h +11 -11
  203. data/src/core/transport/chttp2/internal.h +97 -86
  204. data/src/core/transport/chttp2/parsing.c +25 -25
  205. data/src/core/transport/chttp2/stream_lists.c +26 -3
  206. data/src/core/transport/chttp2/stream_map.c +13 -14
  207. data/src/core/transport/chttp2/stream_map.h +6 -7
  208. data/src/core/transport/chttp2/timeout_encoding.c +19 -16
  209. data/src/core/transport/chttp2/varint.c +8 -9
  210. data/src/core/transport/chttp2/varint.h +7 -8
  211. data/src/core/transport/chttp2/writing.c +26 -23
  212. data/src/core/transport/chttp2_transport.c +133 -92
  213. data/src/core/transport/connectivity_state.c +6 -6
  214. data/src/core/transport/metadata.c +18 -18
  215. data/src/core/transport/metadata.h +5 -5
  216. data/src/core/transport/static_metadata.c +15 -16
  217. data/src/core/transport/static_metadata.h +5 -5
  218. data/src/core/transport/transport.c +5 -5
  219. data/src/core/transport/transport.h +14 -1
  220. data/src/core/tsi/fake_transport_security.c +7 -7
  221. data/src/core/tsi/ssl_transport_security.c +6 -4
  222. data/src/core/tsi/ssl_types.h +55 -0
  223. data/src/ruby/ext/grpc/extconf.rb +51 -14
  224. data/src/ruby/ext/grpc/rb_byte_buffer.c +3 -1
  225. data/src/ruby/ext/grpc/rb_call.c +6 -3
  226. data/src/ruby/ext/grpc/rb_call_credentials.c +4 -0
  227. data/src/ruby/ext/grpc/rb_channel.c +4 -2
  228. data/src/ruby/ext/grpc/rb_channel_args.c +3 -1
  229. data/src/ruby/ext/grpc/rb_channel_credentials.c +3 -1
  230. data/src/ruby/ext/grpc/rb_completion_queue.c +3 -1
  231. data/src/ruby/ext/grpc/rb_event_thread.c +5 -0
  232. data/src/ruby/ext/grpc/rb_grpc.c +11 -3
  233. data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +560 -0
  234. data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +843 -0
  235. data/src/ruby/ext/grpc/rb_loader.c +72 -0
  236. data/src/ruby/ext/grpc/rb_loader.h +40 -0
  237. data/src/ruby/ext/grpc/rb_server.c +3 -1
  238. data/src/ruby/ext/grpc/rb_server_credentials.c +4 -2
  239. data/src/ruby/lib/grpc/generic/bidi_call.rb +1 -1
  240. data/src/ruby/lib/grpc/generic/rpc_desc.rb +1 -1
  241. data/src/ruby/lib/grpc/generic/rpc_server.rb +1 -1
  242. data/src/ruby/lib/grpc/grpc.rb +34 -0
  243. data/src/ruby/lib/grpc/version.rb +1 -1
  244. data/src/ruby/spec/pb/health/checker_spec.rb +1 -1
  245. data/third_party/boringssl/crypto/aes/aes.c +1142 -0
  246. data/third_party/boringssl/crypto/aes/internal.h +87 -0
  247. data/third_party/boringssl/crypto/aes/mode_wrappers.c +108 -0
  248. data/third_party/boringssl/crypto/asn1/a_bitstr.c +255 -0
  249. data/third_party/boringssl/crypto/asn1/a_bool.c +112 -0
  250. data/third_party/boringssl/crypto/asn1/a_bytes.c +317 -0
  251. data/third_party/boringssl/crypto/asn1/a_d2i_fp.c +286 -0
  252. data/third_party/boringssl/crypto/asn1/a_dup.c +103 -0
  253. data/third_party/boringssl/crypto/asn1/a_enum.c +183 -0
  254. data/third_party/boringssl/crypto/asn1/a_gentm.c +255 -0
  255. data/third_party/boringssl/crypto/asn1/a_i2d_fp.c +154 -0
  256. data/third_party/boringssl/crypto/asn1/a_int.c +456 -0
  257. data/third_party/boringssl/crypto/asn1/a_mbstr.c +390 -0
  258. data/third_party/boringssl/crypto/asn1/a_object.c +412 -0
  259. data/third_party/boringssl/crypto/asn1/a_octet.c +70 -0
  260. data/third_party/boringssl/crypto/asn1/a_print.c +119 -0
  261. data/third_party/boringssl/crypto/asn1/a_strnid.c +286 -0
  262. data/third_party/boringssl/crypto/asn1/a_time.c +221 -0
  263. data/third_party/boringssl/crypto/asn1/a_type.c +160 -0
  264. data/third_party/boringssl/crypto/asn1/a_utctm.c +342 -0
  265. data/third_party/boringssl/crypto/asn1/a_utf8.c +210 -0
  266. data/third_party/boringssl/crypto/asn1/asn1_lib.c +510 -0
  267. data/third_party/boringssl/crypto/asn1/asn1_locl.h +73 -0
  268. data/third_party/boringssl/crypto/asn1/asn1_par.c +444 -0
  269. data/third_party/boringssl/crypto/asn1/asn_pack.c +104 -0
  270. data/third_party/boringssl/crypto/asn1/bio_asn1.c +496 -0
  271. data/third_party/boringssl/crypto/asn1/bio_ndef.c +254 -0
  272. data/third_party/boringssl/crypto/asn1/f_enum.c +206 -0
  273. data/third_party/boringssl/crypto/asn1/f_int.c +210 -0
  274. data/third_party/boringssl/crypto/asn1/f_string.c +204 -0
  275. data/third_party/boringssl/crypto/asn1/t_bitst.c +102 -0
  276. data/third_party/boringssl/crypto/asn1/t_pkey.c +112 -0
  277. data/third_party/boringssl/crypto/asn1/tasn_dec.c +1342 -0
  278. data/third_party/boringssl/crypto/asn1/tasn_enc.c +695 -0
  279. data/third_party/boringssl/crypto/asn1/tasn_fre.c +264 -0
  280. data/third_party/boringssl/crypto/asn1/tasn_new.c +398 -0
  281. data/third_party/boringssl/crypto/asn1/tasn_prn.c +642 -0
  282. data/third_party/boringssl/crypto/asn1/tasn_typ.c +137 -0
  283. data/third_party/boringssl/crypto/asn1/tasn_utl.c +266 -0
  284. data/third_party/boringssl/crypto/asn1/x_bignum.c +143 -0
  285. data/third_party/boringssl/crypto/asn1/x_long.c +182 -0
  286. data/third_party/boringssl/crypto/base64/base64.c +478 -0
  287. data/third_party/boringssl/crypto/bio/bio.c +608 -0
  288. data/third_party/boringssl/crypto/bio/bio_mem.c +327 -0
  289. data/third_party/boringssl/crypto/bio/buffer.c +496 -0
  290. data/third_party/boringssl/crypto/bio/connect.c +544 -0
  291. data/third_party/boringssl/crypto/bio/fd.c +270 -0
  292. data/third_party/boringssl/crypto/bio/file.c +349 -0
  293. data/third_party/boringssl/crypto/bio/hexdump.c +192 -0
  294. data/third_party/boringssl/crypto/bio/internal.h +108 -0
  295. data/third_party/boringssl/crypto/bio/pair.c +803 -0
  296. data/third_party/boringssl/crypto/bio/printf.c +119 -0
  297. data/third_party/boringssl/crypto/bio/socket.c +195 -0
  298. data/third_party/boringssl/crypto/bio/socket_helper.c +113 -0
  299. data/third_party/boringssl/crypto/bn/add.c +377 -0
  300. data/third_party/boringssl/crypto/bn/asm/x86_64-gcc.c +599 -0
  301. data/third_party/boringssl/crypto/bn/bn.c +341 -0
  302. data/third_party/boringssl/crypto/bn/bn_asn1.c +93 -0
  303. data/third_party/boringssl/crypto/bn/cmp.c +200 -0
  304. data/third_party/boringssl/crypto/bn/convert.c +597 -0
  305. data/third_party/boringssl/crypto/bn/ctx.c +311 -0
  306. data/third_party/boringssl/crypto/bn/div.c +625 -0
  307. data/third_party/boringssl/crypto/bn/exponentiation.c +1544 -0
  308. data/third_party/boringssl/crypto/bn/gcd.c +711 -0
  309. data/third_party/boringssl/crypto/bn/generic.c +1019 -0
  310. data/third_party/boringssl/crypto/bn/internal.h +294 -0
  311. data/third_party/boringssl/crypto/bn/kronecker.c +175 -0
  312. data/third_party/boringssl/crypto/bn/montgomery.c +561 -0
  313. data/third_party/boringssl/crypto/bn/mul.c +888 -0
  314. data/third_party/boringssl/crypto/bn/prime.c +845 -0
  315. data/third_party/boringssl/crypto/bn/random.c +326 -0
  316. data/third_party/boringssl/crypto/bn/rsaz_exp.c +326 -0
  317. data/third_party/boringssl/crypto/bn/rsaz_exp.h +56 -0
  318. data/third_party/boringssl/crypto/bn/shift.c +299 -0
  319. data/third_party/boringssl/crypto/bn/sqrt.c +505 -0
  320. data/third_party/boringssl/crypto/buf/buf.c +235 -0
  321. data/third_party/boringssl/crypto/bytestring/ber.c +221 -0
  322. data/third_party/boringssl/crypto/bytestring/cbb.c +411 -0
  323. data/third_party/boringssl/crypto/bytestring/cbs.c +415 -0
  324. data/third_party/boringssl/crypto/bytestring/internal.h +46 -0
  325. data/third_party/boringssl/crypto/chacha/chacha_generic.c +140 -0
  326. data/third_party/boringssl/crypto/chacha/chacha_vec.c +323 -0
  327. data/third_party/boringssl/crypto/cipher/aead.c +167 -0
  328. data/third_party/boringssl/crypto/cipher/cipher.c +652 -0
  329. data/third_party/boringssl/crypto/cipher/derive_key.c +154 -0
  330. data/third_party/boringssl/crypto/cipher/e_aes.c +1767 -0
  331. data/third_party/boringssl/crypto/cipher/e_chacha20poly1305.c +311 -0
  332. data/third_party/boringssl/crypto/cipher/e_des.c +207 -0
  333. data/third_party/boringssl/crypto/cipher/e_null.c +85 -0
  334. data/third_party/boringssl/crypto/cipher/e_rc2.c +443 -0
  335. data/third_party/boringssl/crypto/cipher/e_rc4.c +87 -0
  336. data/third_party/boringssl/crypto/cipher/e_ssl3.c +463 -0
  337. data/third_party/boringssl/crypto/cipher/e_tls.c +673 -0
  338. data/third_party/boringssl/crypto/cipher/internal.h +164 -0
  339. data/third_party/boringssl/crypto/cipher/tls_cbc.c +495 -0
  340. data/third_party/boringssl/crypto/cmac/cmac.c +239 -0
  341. data/third_party/boringssl/crypto/conf/conf.c +778 -0
  342. data/third_party/boringssl/crypto/conf/conf_def.h +127 -0
  343. data/third_party/boringssl/crypto/conf/internal.h +31 -0
  344. data/third_party/boringssl/crypto/cpu-arm.c +199 -0
  345. data/third_party/boringssl/crypto/cpu-intel.c +261 -0
  346. data/third_party/boringssl/crypto/crypto.c +140 -0
  347. data/third_party/boringssl/crypto/curve25519/curve25519.c +4897 -0
  348. data/third_party/boringssl/crypto/des/des.c +771 -0
  349. data/third_party/boringssl/crypto/des/internal.h +212 -0
  350. data/third_party/boringssl/crypto/dh/check.c +180 -0
  351. data/third_party/boringssl/crypto/dh/dh.c +463 -0
  352. data/third_party/boringssl/crypto/dh/dh_asn1.c +84 -0
  353. data/third_party/boringssl/crypto/dh/internal.h +80 -0
  354. data/third_party/boringssl/crypto/dh/params.c +301 -0
  355. data/third_party/boringssl/crypto/digest/digest.c +248 -0
  356. data/third_party/boringssl/crypto/digest/digests.c +321 -0
  357. data/third_party/boringssl/crypto/digest/internal.h +112 -0
  358. data/third_party/boringssl/crypto/digest/md32_common.h +322 -0
  359. data/third_party/boringssl/crypto/directory.h +66 -0
  360. data/third_party/boringssl/crypto/directory_posix.c +108 -0
  361. data/third_party/boringssl/crypto/directory_win.c +144 -0
  362. data/third_party/boringssl/crypto/dsa/dsa.c +908 -0
  363. data/third_party/boringssl/crypto/dsa/dsa_asn1.c +150 -0
  364. data/third_party/boringssl/crypto/dsa/internal.h +78 -0
  365. data/third_party/boringssl/crypto/ec/ec.c +889 -0
  366. data/third_party/boringssl/crypto/ec/ec_asn1.c +586 -0
  367. data/third_party/boringssl/crypto/ec/ec_key.c +482 -0
  368. data/third_party/boringssl/crypto/ec/ec_montgomery.c +280 -0
  369. data/third_party/boringssl/crypto/ec/internal.h +318 -0
  370. data/third_party/boringssl/crypto/ec/oct.c +416 -0
  371. data/third_party/boringssl/crypto/ec/p224-64.c +1305 -0
  372. data/third_party/boringssl/crypto/ec/p256-64.c +1878 -0
  373. data/third_party/boringssl/crypto/ec/p256-x86_64-table.h +9548 -0
  374. data/third_party/boringssl/crypto/ec/p256-x86_64.c +596 -0
  375. data/third_party/boringssl/crypto/ec/simple.c +1313 -0
  376. data/third_party/boringssl/crypto/ec/util-64.c +183 -0
  377. data/third_party/boringssl/crypto/ec/wnaf.c +449 -0
  378. data/third_party/boringssl/crypto/ecdh/ecdh.c +153 -0
  379. data/third_party/boringssl/crypto/ecdsa/ecdsa.c +496 -0
  380. data/third_party/boringssl/crypto/ecdsa/ecdsa_asn1.c +240 -0
  381. data/third_party/boringssl/crypto/engine/engine.c +96 -0
  382. data/third_party/boringssl/crypto/err/err.c +756 -0
  383. data/third_party/boringssl/crypto/evp/algorithm.c +153 -0
  384. data/third_party/boringssl/crypto/evp/digestsign.c +159 -0
  385. data/third_party/boringssl/crypto/evp/evp.c +411 -0
  386. data/third_party/boringssl/crypto/evp/evp_asn1.c +179 -0
  387. data/third_party/boringssl/crypto/evp/evp_ctx.c +477 -0
  388. data/third_party/boringssl/crypto/evp/internal.h +278 -0
  389. data/third_party/boringssl/crypto/evp/p_dsa_asn1.c +588 -0
  390. data/third_party/boringssl/crypto/evp/p_ec.c +283 -0
  391. data/third_party/boringssl/crypto/evp/p_ec_asn1.c +562 -0
  392. data/third_party/boringssl/crypto/evp/p_rsa.c +596 -0
  393. data/third_party/boringssl/crypto/evp/p_rsa_asn1.c +737 -0
  394. data/third_party/boringssl/crypto/evp/pbkdf.c +151 -0
  395. data/third_party/boringssl/crypto/evp/sign.c +151 -0
  396. data/third_party/boringssl/crypto/ex_data.c +294 -0
  397. data/third_party/boringssl/crypto/hkdf/hkdf.c +89 -0
  398. data/third_party/boringssl/crypto/hmac/hmac.c +213 -0
  399. data/third_party/boringssl/crypto/internal.h +532 -0
  400. data/third_party/boringssl/crypto/lhash/lhash.c +346 -0
  401. data/third_party/boringssl/crypto/md4/md4.c +225 -0
  402. data/third_party/boringssl/crypto/md5/md5.c +275 -0
  403. data/third_party/boringssl/crypto/mem.c +200 -0
  404. data/third_party/boringssl/crypto/modes/cbc.c +216 -0
  405. data/third_party/boringssl/crypto/modes/cfb.c +231 -0
  406. data/third_party/boringssl/crypto/modes/ctr.c +226 -0
  407. data/third_party/boringssl/crypto/modes/gcm.c +1252 -0
  408. data/third_party/boringssl/crypto/modes/internal.h +370 -0
  409. data/third_party/boringssl/crypto/modes/ofb.c +108 -0
  410. data/third_party/boringssl/crypto/obj/obj.c +664 -0
  411. data/third_party/boringssl/crypto/obj/obj_dat.h +5257 -0
  412. data/third_party/boringssl/crypto/obj/obj_xref.c +124 -0
  413. data/third_party/boringssl/crypto/obj/obj_xref.h +96 -0
  414. data/third_party/boringssl/crypto/pem/pem_all.c +281 -0
  415. data/third_party/boringssl/crypto/pem/pem_info.c +404 -0
  416. data/third_party/boringssl/crypto/pem/pem_lib.c +835 -0
  417. data/third_party/boringssl/crypto/pem/pem_oth.c +89 -0
  418. data/third_party/boringssl/crypto/pem/pem_pk8.c +244 -0
  419. data/third_party/boringssl/crypto/pem/pem_pkey.c +312 -0
  420. data/third_party/boringssl/crypto/pem/pem_x509.c +65 -0
  421. data/third_party/boringssl/crypto/pem/pem_xaux.c +66 -0
  422. data/third_party/boringssl/crypto/pkcs8/internal.h +83 -0
  423. data/third_party/boringssl/crypto/pkcs8/p5_pbe.c +150 -0
  424. data/third_party/boringssl/crypto/pkcs8/p5_pbev2.c +440 -0
  425. data/third_party/boringssl/crypto/pkcs8/p8_pkey.c +85 -0
  426. data/third_party/boringssl/crypto/pkcs8/pkcs8.c +1217 -0
  427. data/third_party/boringssl/crypto/poly1305/poly1305.c +331 -0
  428. data/third_party/boringssl/crypto/poly1305/poly1305_arm.c +301 -0
  429. data/third_party/boringssl/crypto/poly1305/poly1305_vec.c +892 -0
  430. data/third_party/boringssl/crypto/rand/internal.h +32 -0
  431. data/third_party/boringssl/crypto/rand/rand.c +239 -0
  432. data/third_party/boringssl/crypto/rand/urandom.c +223 -0
  433. data/third_party/boringssl/crypto/rand/windows.c +56 -0
  434. data/third_party/boringssl/crypto/rc4/rc4.c +283 -0
  435. data/third_party/boringssl/crypto/refcount_c11.c +67 -0
  436. data/third_party/boringssl/crypto/refcount_lock.c +53 -0
  437. data/third_party/boringssl/crypto/rsa/blinding.c +462 -0
  438. data/third_party/boringssl/crypto/rsa/internal.h +164 -0
  439. data/third_party/boringssl/crypto/rsa/padding.c +711 -0
  440. data/third_party/boringssl/crypto/rsa/rsa.c +808 -0
  441. data/third_party/boringssl/crypto/rsa/rsa_asn1.c +473 -0
  442. data/third_party/boringssl/crypto/rsa/rsa_impl.c +1138 -0
  443. data/third_party/boringssl/crypto/sha/sha1.c +337 -0
  444. data/third_party/boringssl/crypto/sha/sha256.c +327 -0
  445. data/third_party/boringssl/crypto/sha/sha512.c +607 -0
  446. data/third_party/boringssl/crypto/stack/stack.c +386 -0
  447. data/third_party/boringssl/crypto/test/scoped_types.h +137 -0
  448. data/third_party/boringssl/crypto/test/test_util.h +35 -0
  449. data/third_party/boringssl/crypto/thread.c +101 -0
  450. data/third_party/boringssl/crypto/thread_none.c +55 -0
  451. data/third_party/boringssl/crypto/thread_pthread.c +167 -0
  452. data/third_party/boringssl/crypto/thread_win.c +282 -0
  453. data/third_party/boringssl/crypto/time_support.c +212 -0
  454. data/third_party/boringssl/crypto/x509/a_digest.c +97 -0
  455. data/third_party/boringssl/crypto/x509/a_sign.c +136 -0
  456. data/third_party/boringssl/crypto/x509/a_strex.c +564 -0
  457. data/third_party/boringssl/crypto/x509/a_verify.c +133 -0
  458. data/third_party/boringssl/crypto/x509/asn1_gen.c +873 -0
  459. data/third_party/boringssl/crypto/x509/by_dir.c +491 -0
  460. data/third_party/boringssl/crypto/x509/by_file.c +295 -0
  461. data/third_party/boringssl/crypto/x509/charmap.h +15 -0
  462. data/third_party/boringssl/crypto/x509/i2d_pr.c +84 -0
  463. data/third_party/boringssl/crypto/x509/pkcs7.c +353 -0
  464. data/third_party/boringssl/crypto/x509/t_crl.c +129 -0
  465. data/third_party/boringssl/crypto/x509/t_req.c +246 -0
  466. data/third_party/boringssl/crypto/x509/t_x509.c +500 -0
  467. data/third_party/boringssl/crypto/x509/t_x509a.c +109 -0
  468. data/third_party/boringssl/crypto/x509/vpm_int.h +70 -0
  469. data/third_party/boringssl/crypto/x509/x509.c +152 -0
  470. data/third_party/boringssl/crypto/x509/x509_att.c +353 -0
  471. data/third_party/boringssl/crypto/x509/x509_cmp.c +490 -0
  472. data/third_party/boringssl/crypto/x509/x509_d2.c +105 -0
  473. data/third_party/boringssl/crypto/x509/x509_def.c +88 -0
  474. data/third_party/boringssl/crypto/x509/x509_ext.c +206 -0
  475. data/third_party/boringssl/crypto/x509/x509_lu.c +738 -0
  476. data/third_party/boringssl/crypto/x509/x509_obj.c +191 -0
  477. data/third_party/boringssl/crypto/x509/x509_r2x.c +113 -0
  478. data/third_party/boringssl/crypto/x509/x509_req.c +315 -0
  479. data/third_party/boringssl/crypto/x509/x509_set.c +154 -0
  480. data/third_party/boringssl/crypto/x509/x509_trs.c +304 -0
  481. data/third_party/boringssl/crypto/x509/x509_txt.c +209 -0
  482. data/third_party/boringssl/crypto/x509/x509_v3.c +271 -0
  483. data/third_party/boringssl/crypto/x509/x509_vfy.c +2456 -0
  484. data/third_party/boringssl/crypto/x509/x509_vpm.c +672 -0
  485. data/third_party/boringssl/crypto/x509/x509cset.c +172 -0
  486. data/third_party/boringssl/crypto/x509/x509name.c +381 -0
  487. data/third_party/boringssl/crypto/x509/x509rset.c +80 -0
  488. data/third_party/boringssl/crypto/x509/x509spki.c +135 -0
  489. data/third_party/boringssl/crypto/x509/x509type.c +128 -0
  490. data/third_party/boringssl/crypto/x509/x_algor.c +154 -0
  491. data/third_party/boringssl/crypto/x509/x_all.c +547 -0
  492. data/third_party/boringssl/crypto/x509/x_attrib.c +117 -0
  493. data/third_party/boringssl/crypto/x509/x_crl.c +560 -0
  494. data/third_party/boringssl/crypto/x509/x_exten.c +75 -0
  495. data/third_party/boringssl/crypto/x509/x_info.c +95 -0
  496. data/third_party/boringssl/crypto/x509/x_name.c +538 -0
  497. data/third_party/boringssl/crypto/x509/x_pkey.c +100 -0
  498. data/third_party/boringssl/crypto/x509/x_pubkey.c +384 -0
  499. data/third_party/boringssl/crypto/x509/x_req.c +112 -0
  500. data/third_party/boringssl/crypto/x509/x_sig.c +69 -0
  501. data/third_party/boringssl/crypto/x509/x_spki.c +78 -0
  502. data/third_party/boringssl/crypto/x509/x_val.c +69 -0
  503. data/third_party/boringssl/crypto/x509/x_x509.c +227 -0
  504. data/third_party/boringssl/crypto/x509/x_x509a.c +197 -0
  505. data/third_party/boringssl/crypto/x509v3/ext_dat.h +129 -0
  506. data/third_party/boringssl/crypto/x509v3/pcy_cache.c +299 -0
  507. data/third_party/boringssl/crypto/x509v3/pcy_data.c +137 -0
  508. data/third_party/boringssl/crypto/x509v3/pcy_int.h +212 -0
  509. data/third_party/boringssl/crypto/x509v3/pcy_lib.c +165 -0
  510. data/third_party/boringssl/crypto/x509v3/pcy_map.c +133 -0
  511. data/third_party/boringssl/crypto/x509v3/pcy_node.c +197 -0
  512. data/third_party/boringssl/crypto/x509v3/pcy_tree.c +876 -0
  513. data/third_party/boringssl/crypto/x509v3/v3_akey.c +212 -0
  514. data/third_party/boringssl/crypto/x509v3/v3_akeya.c +71 -0
  515. data/third_party/boringssl/crypto/x509v3/v3_alt.c +622 -0
  516. data/third_party/boringssl/crypto/x509v3/v3_bcons.c +126 -0
  517. data/third_party/boringssl/crypto/x509v3/v3_bitst.c +141 -0
  518. data/third_party/boringssl/crypto/x509v3/v3_conf.c +459 -0
  519. data/third_party/boringssl/crypto/x509v3/v3_cpols.c +475 -0
  520. data/third_party/boringssl/crypto/x509v3/v3_crld.c +616 -0
  521. data/third_party/boringssl/crypto/x509v3/v3_enum.c +98 -0
  522. data/third_party/boringssl/crypto/x509v3/v3_extku.c +145 -0
  523. data/third_party/boringssl/crypto/x509v3/v3_genn.c +252 -0
  524. data/third_party/boringssl/crypto/x509v3/v3_ia5.c +117 -0
  525. data/third_party/boringssl/crypto/x509v3/v3_info.c +200 -0
  526. data/third_party/boringssl/crypto/x509v3/v3_int.c +87 -0
  527. data/third_party/boringssl/crypto/x509v3/v3_lib.c +335 -0
  528. data/third_party/boringssl/crypto/x509v3/v3_ncons.c +510 -0
  529. data/third_party/boringssl/crypto/x509v3/v3_pci.c +335 -0
  530. data/third_party/boringssl/crypto/x509v3/v3_pcia.c +56 -0
  531. data/third_party/boringssl/crypto/x509v3/v3_pcons.c +142 -0
  532. data/third_party/boringssl/crypto/x509v3/v3_pku.c +109 -0
  533. data/third_party/boringssl/crypto/x509v3/v3_pmaps.c +156 -0
  534. data/third_party/boringssl/crypto/x509v3/v3_prn.c +207 -0
  535. data/third_party/boringssl/crypto/x509v3/v3_purp.c +805 -0
  536. data/third_party/boringssl/crypto/x509v3/v3_skey.c +148 -0
  537. data/third_party/boringssl/crypto/x509v3/v3_sxnet.c +266 -0
  538. data/third_party/boringssl/crypto/x509v3/v3_utl.c +1322 -0
  539. data/third_party/boringssl/include/openssl/aead.h +346 -0
  540. data/third_party/boringssl/include/openssl/aes.h +158 -0
  541. data/third_party/boringssl/include/openssl/arm_arch.h +127 -0
  542. data/third_party/boringssl/include/openssl/asn1.h +1168 -0
  543. data/third_party/boringssl/include/openssl/asn1_mac.h +75 -0
  544. data/third_party/boringssl/include/openssl/asn1t.h +906 -0
  545. data/third_party/boringssl/include/openssl/base.h +261 -0
  546. data/third_party/boringssl/include/openssl/base64.h +184 -0
  547. data/third_party/boringssl/include/openssl/bio.h +902 -0
  548. data/third_party/boringssl/include/openssl/blowfish.h +93 -0
  549. data/third_party/boringssl/include/openssl/bn.h +885 -0
  550. data/third_party/boringssl/include/openssl/buf.h +118 -0
  551. data/third_party/boringssl/include/openssl/buffer.h +18 -0
  552. data/third_party/boringssl/include/openssl/bytestring.h +360 -0
  553. data/third_party/boringssl/include/openssl/cast.h +96 -0
  554. data/third_party/boringssl/include/openssl/chacha.h +37 -0
  555. data/third_party/boringssl/include/openssl/cipher.h +571 -0
  556. data/third_party/boringssl/include/openssl/cmac.h +76 -0
  557. data/third_party/boringssl/include/openssl/conf.h +145 -0
  558. data/third_party/boringssl/include/openssl/cpu.h +184 -0
  559. data/third_party/boringssl/include/openssl/crypto.h +68 -0
  560. data/third_party/boringssl/include/openssl/curve25519.h +88 -0
  561. data/third_party/boringssl/include/openssl/des.h +177 -0
  562. data/third_party/boringssl/include/openssl/dh.h +238 -0
  563. data/third_party/boringssl/include/openssl/digest.h +258 -0
  564. data/third_party/boringssl/include/openssl/dsa.h +343 -0
  565. data/third_party/boringssl/include/openssl/dtls1.h +16 -0
  566. data/third_party/boringssl/include/openssl/ec.h +355 -0
  567. data/third_party/boringssl/include/openssl/ec_key.h +280 -0
  568. data/third_party/boringssl/include/openssl/ecdh.h +102 -0
  569. data/third_party/boringssl/include/openssl/ecdsa.h +206 -0
  570. data/third_party/boringssl/include/openssl/engine.h +98 -0
  571. data/third_party/boringssl/include/openssl/err.h +487 -0
  572. data/third_party/boringssl/include/openssl/evp.h +750 -0
  573. data/third_party/boringssl/include/openssl/ex_data.h +213 -0
  574. data/third_party/boringssl/include/openssl/hkdf.h +44 -0
  575. data/third_party/boringssl/include/openssl/hmac.h +160 -0
  576. data/third_party/boringssl/include/openssl/lhash.h +192 -0
  577. data/third_party/boringssl/include/openssl/lhash_macros.h +132 -0
  578. data/third_party/boringssl/include/openssl/md4.h +102 -0
  579. data/third_party/boringssl/include/openssl/md5.h +107 -0
  580. data/third_party/boringssl/include/openssl/mem.h +140 -0
  581. data/third_party/boringssl/include/openssl/obj.h +198 -0
  582. data/third_party/boringssl/include/openssl/obj_mac.h +4140 -0
  583. data/third_party/boringssl/include/openssl/objects.h +18 -0
  584. data/third_party/boringssl/include/openssl/opensslfeatures.h +60 -0
  585. data/third_party/boringssl/include/openssl/opensslv.h +18 -0
  586. data/third_party/boringssl/include/openssl/ossl_typ.h +18 -0
  587. data/third_party/boringssl/include/openssl/pem.h +521 -0
  588. data/third_party/boringssl/include/openssl/pkcs12.h +18 -0
  589. data/third_party/boringssl/include/openssl/pkcs7.h +16 -0
  590. data/third_party/boringssl/include/openssl/pkcs8.h +220 -0
  591. data/third_party/boringssl/include/openssl/poly1305.h +51 -0
  592. data/third_party/boringssl/include/openssl/pqueue.h +146 -0
  593. data/third_party/boringssl/include/openssl/rand.h +113 -0
  594. data/third_party/boringssl/include/openssl/rc4.h +90 -0
  595. data/third_party/boringssl/include/openssl/rsa.h +637 -0
  596. data/third_party/boringssl/include/openssl/safestack.h +16 -0
  597. data/third_party/boringssl/include/openssl/sha.h +256 -0
  598. data/third_party/boringssl/include/openssl/srtp.h +18 -0
  599. data/third_party/boringssl/include/openssl/ssl.h +4466 -0
  600. data/third_party/boringssl/include/openssl/ssl3.h +441 -0
  601. data/third_party/boringssl/include/openssl/stack.h +298 -0
  602. data/third_party/boringssl/include/openssl/stack_macros.h +4190 -0
  603. data/third_party/boringssl/include/openssl/thread.h +173 -0
  604. data/third_party/boringssl/include/openssl/time_support.h +90 -0
  605. data/third_party/boringssl/include/openssl/tls1.h +653 -0
  606. data/third_party/boringssl/include/openssl/type_check.h +91 -0
  607. data/third_party/boringssl/include/openssl/x509.h +1258 -0
  608. data/third_party/boringssl/include/openssl/x509_vfy.h +611 -0
  609. data/third_party/boringssl/include/openssl/x509v3.h +798 -0
  610. data/third_party/boringssl/ssl/custom_extensions.c +257 -0
  611. data/third_party/boringssl/ssl/d1_both.c +880 -0
  612. data/third_party/boringssl/ssl/d1_clnt.c +566 -0
  613. data/third_party/boringssl/ssl/d1_lib.c +340 -0
  614. data/third_party/boringssl/ssl/d1_meth.c +130 -0
  615. data/third_party/boringssl/ssl/d1_pkt.c +578 -0
  616. data/third_party/boringssl/ssl/d1_srtp.c +234 -0
  617. data/third_party/boringssl/ssl/d1_srvr.c +485 -0
  618. data/third_party/boringssl/ssl/dtls_record.c +308 -0
  619. data/third_party/boringssl/ssl/internal.h +1276 -0
  620. data/third_party/boringssl/ssl/pqueue/pqueue.c +197 -0
  621. data/third_party/boringssl/ssl/s3_both.c +571 -0
  622. data/third_party/boringssl/ssl/s3_clnt.c +2241 -0
  623. data/third_party/boringssl/ssl/s3_enc.c +494 -0
  624. data/third_party/boringssl/ssl/s3_lib.c +587 -0
  625. data/third_party/boringssl/ssl/s3_meth.c +166 -0
  626. data/third_party/boringssl/ssl/s3_pkt.c +732 -0
  627. data/third_party/boringssl/ssl/s3_srvr.c +2536 -0
  628. data/third_party/boringssl/ssl/ssl_aead_ctx.c +300 -0
  629. data/third_party/boringssl/ssl/ssl_asn1.c +718 -0
  630. data/third_party/boringssl/ssl/ssl_buffer.c +319 -0
  631. data/third_party/boringssl/ssl/ssl_cert.c +539 -0
  632. data/third_party/boringssl/ssl/ssl_cipher.c +2003 -0
  633. data/third_party/boringssl/ssl/ssl_file.c +633 -0
  634. data/third_party/boringssl/ssl/ssl_lib.c +2653 -0
  635. data/third_party/boringssl/ssl/ssl_rsa.c +423 -0
  636. data/third_party/boringssl/ssl/ssl_session.c +764 -0
  637. data/third_party/boringssl/ssl/ssl_stat.c +591 -0
  638. data/third_party/boringssl/ssl/t1_enc.c +708 -0
  639. data/third_party/boringssl/ssl/t1_lib.c +2905 -0
  640. data/third_party/boringssl/ssl/test/async_bio.h +45 -0
  641. data/third_party/boringssl/ssl/test/packeted_bio.h +44 -0
  642. data/third_party/boringssl/ssl/test/scoped_types.h +28 -0
  643. data/third_party/boringssl/ssl/test/test_config.h +108 -0
  644. data/third_party/boringssl/ssl/tls_record.c +342 -0
  645. data/third_party/zlib/adler32.c +179 -0
  646. data/third_party/zlib/compress.c +80 -0
  647. data/third_party/zlib/crc32.c +425 -0
  648. data/third_party/zlib/crc32.h +441 -0
  649. data/third_party/zlib/deflate.c +1967 -0
  650. data/third_party/zlib/deflate.h +346 -0
  651. data/third_party/zlib/gzclose.c +25 -0
  652. data/third_party/zlib/gzguts.h +209 -0
  653. data/third_party/zlib/gzlib.c +634 -0
  654. data/third_party/zlib/gzread.c +594 -0
  655. data/third_party/zlib/gzwrite.c +577 -0
  656. data/third_party/zlib/infback.c +640 -0
  657. data/third_party/zlib/inffast.c +340 -0
  658. data/third_party/zlib/inffast.h +11 -0
  659. data/third_party/zlib/inffixed.h +94 -0
  660. data/third_party/zlib/inflate.c +1512 -0
  661. data/third_party/zlib/inflate.h +122 -0
  662. data/third_party/zlib/inftrees.c +306 -0
  663. data/third_party/zlib/inftrees.h +62 -0
  664. data/third_party/zlib/trees.c +1226 -0
  665. data/third_party/zlib/trees.h +128 -0
  666. data/third_party/zlib/uncompr.c +59 -0
  667. data/third_party/zlib/zconf.h +511 -0
  668. data/third_party/zlib/zlib.h +1768 -0
  669. data/third_party/zlib/zutil.c +324 -0
  670. data/third_party/zlib/zutil.h +253 -0
  671. metadata +492 -25
  672. data/Rakefile +0 -63
  673. 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 */