rhodes 3.3.5 → 3.4.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1678) hide show
  1. data/CHANGELOG +3 -1
  2. data/CREDITS +5 -0
  3. data/Rakefile +173 -17
  4. data/doc/build.txt +71 -27
  5. data/doc/configuration.txt +2 -0
  6. data/doc/device-caps.txt +103 -27
  7. data/doc/extensions.txt +49 -33
  8. data/doc/install.txt +15 -12
  9. data/doc/introduction.txt +1 -1
  10. data/doc/nfc.txt +3 -2
  11. data/doc/rhom.txt +22 -1
  12. data/doc/{rhostudio-eclipse.txt → rhostudio-eclipse_outdated.txt} +0 -0
  13. data/doc/rhostudio-test-plan.txt +79 -22
  14. data/doc/simulator.txt +19 -52
  15. data/doc/standard-css.txt +1 -1
  16. data/doc/synchronization.txt +2 -0
  17. data/doc/test-log-debug.txt +149 -1
  18. data/doc/ui.txt +57 -0
  19. data/lib/build/jake.rb +33 -22
  20. data/lib/extensions/barcode/ext/barcode/platform/iphone/Barcode.xcodeproj/project.pbxproj +4 -10
  21. data/lib/extensions/debugger/debugger.rb +18 -5
  22. data/lib/extensions/digest-md5/digest/md5.rb +0 -0
  23. data/lib/extensions/digest-md5/ext/iphone/Dmd5.xcodeproj/project.pbxproj +4 -10
  24. data/lib/extensions/digest-sha1/digest/sha1.rb +0 -0
  25. data/lib/extensions/digest-sha1/ext/iphone/Dsha1.xcodeproj/project.pbxproj +4 -10
  26. data/lib/extensions/digest-sha2/digest/sha2.rb +0 -0
  27. data/lib/extensions/digest-sha2/ext.yml +2 -0
  28. data/lib/extensions/digest-sha2/ext/Rakefile +128 -0
  29. data/lib/extensions/digest-sha2/ext/build +12 -0
  30. data/lib/extensions/digest-sha2/ext/build.bat +1 -0
  31. data/lib/extensions/digest-sha2/ext/depend +6 -0
  32. data/lib/extensions/digest-sha2/ext/digest-sha2.sln +44 -0
  33. data/lib/extensions/digest-sha2/ext/digest-sha2.vcproj +666 -0
  34. data/lib/extensions/digest-sha2/ext/extconf.rb +27 -0
  35. data/lib/extensions/digest-sha2/ext/iphone/Dsha2.xcodeproj/project.pbxproj +272 -0
  36. data/lib/extensions/digest-sha2/ext/iphone/Dsha2_Prefix.pch +7 -0
  37. data/lib/extensions/digest-sha2/ext/iphone/Rakefile +79 -0
  38. data/lib/extensions/digest-sha2/ext/sha2.c +1070 -0
  39. data/lib/extensions/digest-sha2/ext/sha2.h +225 -0
  40. data/lib/extensions/digest-sha2/ext/sha2.rb +1 -0
  41. data/lib/extensions/digest-sha2/ext/sha2init.c +56 -0
  42. data/lib/extensions/digest-sha2/ext/sha2ossl.c +11 -0
  43. data/lib/extensions/digest-sha2/ext/sha2ossl.h +17 -0
  44. data/lib/extensions/digest-sha2/sha2/sha2.rb +74 -0
  45. data/lib/extensions/digest/digest.so.rb +0 -0
  46. data/lib/extensions/digest/ext/iphone/Digest.xcodeproj/project.pbxproj +4 -10
  47. data/lib/extensions/esri/ext/esri/platform/iphone/ESRI.xcodeproj/project.pbxproj +4 -10
  48. data/lib/extensions/ezcrypto/ext/CHANGELOG +85 -0
  49. data/lib/extensions/ezcrypto/ext/MIT-LICENSE +21 -0
  50. data/lib/extensions/ezcrypto/ext/README.rdoc +152 -0
  51. data/lib/extensions/ezcrypto/ext/README_ACTIVE_CRYPTO +122 -0
  52. data/lib/extensions/ezcrypto/ext/README_DIGITAL_SIGNATURES +55 -0
  53. data/lib/extensions/ezcrypto/ext/rakefile +200 -0
  54. data/lib/extensions/ezcrypto/ext/test/active_crypto_test.rb +211 -0
  55. data/lib/extensions/ezcrypto/ext/test/agree2.com.cert +31 -0
  56. data/lib/extensions/ezcrypto/ext/test/association_key_holder_test.rb +38 -0
  57. data/lib/extensions/ezcrypto/ext/test/database.yml +18 -0
  58. data/lib/extensions/ezcrypto/ext/test/digest_test.rb +51 -0
  59. data/lib/extensions/ezcrypto/ext/test/dsakey.pem +12 -0
  60. data/lib/extensions/ezcrypto/ext/test/dsapubkey.pem +12 -0
  61. data/lib/extensions/ezcrypto/ext/test/dsig_test.rb +288 -0
  62. data/lib/extensions/ezcrypto/ext/test/encrypt_test.rb +41 -0
  63. data/lib/extensions/ezcrypto/ext/test/ezcrypto_test.rb +212 -0
  64. data/lib/extensions/ezcrypto/ext/test/key_holder_test.rb +44 -0
  65. data/lib/extensions/ezcrypto/ext/test/protectedsigner.pem +12 -0
  66. data/lib/extensions/ezcrypto/ext/test/sf-class2-root.crt +24 -0
  67. data/lib/extensions/ezcrypto/ext/test/sf_intermediate.crt +29 -0
  68. data/lib/extensions/ezcrypto/ext/test/test_helper.rb +35 -0
  69. data/lib/extensions/ezcrypto/ext/test/testchild.pem +15 -0
  70. data/lib/extensions/ezcrypto/ext/test/testchild.req +12 -0
  71. data/lib/extensions/ezcrypto/ext/test/testpub.pem +4 -0
  72. data/lib/extensions/ezcrypto/ext/test/testsigner.cert +20 -0
  73. data/lib/extensions/ezcrypto/ext/test/testsigner.pem +9 -0
  74. data/lib/extensions/ezcrypto/ext/test/valicert_class2_root.crt +18 -0
  75. data/lib/extensions/ezcrypto/ezcrypto.rb +1 -0
  76. data/lib/extensions/ezcrypto/ezcrypto/ezcrypto.rb +612 -0
  77. data/lib/extensions/ezcrypto/ezcrypto/ezsig.rb +535 -0
  78. data/lib/extensions/ezcrypto/ezcrypto/trusted.pem +2363 -0
  79. data/lib/extensions/fcntl/ext/iphone/Fcntl.xcodeproj/project.pbxproj +4 -10
  80. data/lib/extensions/fcntl/fcntl.rb +0 -0
  81. data/lib/extensions/nfc/ext/nfc/platform/android/src/com/rhomobile/nfc/Nfc.java +9 -22
  82. data/lib/extensions/openssl.so.src/ext.yml +2 -0
  83. data/lib/extensions/openssl.so.src/ext/Rakefile +107 -0
  84. data/lib/extensions/openssl.so.src/ext/build +12 -0
  85. data/lib/extensions/openssl.so.src/ext/build.bat +1 -0
  86. data/lib/extensions/openssl.so/ext.yml +9 -0
  87. data/lib/extensions/openssl.so/ext/Rakefile +139 -0
  88. data/lib/extensions/openssl.so/ext/android/libopenssl.so.a +0 -0
  89. data/lib/extensions/openssl.so/ext/build +12 -0
  90. data/lib/extensions/openssl.so/ext/build.bat +1 -0
  91. data/lib/extensions/openssl.so/ext/iphone/Rakefile +79 -0
  92. data/lib/extensions/openssl.so/ext/iphone/Release-iphoneos/libopenssl.so.a +0 -0
  93. data/lib/extensions/openssl.so/ext/iphone/Release-iphonesimulator/libopenssl.so.a +0 -0
  94. data/lib/extensions/openssl.so/ext/iphone/openssl/openssl.xcodeproj/project.pbxproj +4300 -0
  95. data/lib/extensions/openssl.so/ext/iphone/openssl/openssl/openssl-Prefix.pch +7 -0
  96. data/lib/extensions/openssl.so/ext/sources/apps/apps.h +373 -0
  97. data/lib/extensions/openssl.so/ext/sources/apps/progs.h +366 -0
  98. data/lib/extensions/openssl.so/ext/sources/apps/s_apps.h +176 -0
  99. data/lib/extensions/openssl.so/ext/sources/apps/testdsa.h +217 -0
  100. data/lib/extensions/openssl.so/ext/sources/apps/testrsa.h +518 -0
  101. data/lib/extensions/openssl.so/ext/sources/crypto/LPdir_unix.c +127 -0
  102. data/lib/extensions/openssl.so/ext/sources/crypto/LPdir_win.c +153 -0
  103. data/lib/extensions/openssl.so/ext/sources/crypto/LPdir_win32.c +30 -0
  104. data/lib/extensions/openssl.so/ext/sources/crypto/aes/aes.h +147 -0
  105. data/lib/extensions/openssl.so/ext/sources/crypto/aes/aes_cbc.c +63 -0
  106. data/lib/extensions/openssl.so/ext/sources/crypto/aes/aes_cfb.c +81 -0
  107. data/lib/extensions/openssl.so/ext/sources/crypto/aes/aes_core.c +1358 -0
  108. data/lib/extensions/openssl.so/ext/sources/crypto/aes/aes_ctr.c +61 -0
  109. data/lib/extensions/openssl.so/ext/sources/crypto/aes/aes_ecb.c +73 -0
  110. data/lib/extensions/openssl.so/ext/sources/crypto/aes/aes_ige.c +323 -0
  111. data/lib/extensions/openssl.so/ext/sources/crypto/aes/aes_locl.h +89 -0
  112. data/lib/extensions/openssl.so/ext/sources/crypto/aes/aes_misc.c +85 -0
  113. data/lib/extensions/openssl.so/ext/sources/crypto/aes/aes_ofb.c +60 -0
  114. data/lib/extensions/openssl.so/ext/sources/crypto/aes/aes_wrap.c +259 -0
  115. data/lib/extensions/openssl.so/ext/sources/crypto/arm_arch.h +51 -0
  116. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/a_bitstr.c +248 -0
  117. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/a_bool.c +114 -0
  118. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/a_bytes.c +314 -0
  119. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/a_d2i_fp.c +286 -0
  120. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/a_digest.c +113 -0
  121. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/a_dup.c +109 -0
  122. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/a_enum.c +182 -0
  123. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/a_gentm.c +263 -0
  124. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/a_i2d_fp.c +163 -0
  125. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/a_int.c +458 -0
  126. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/a_mbstr.c +400 -0
  127. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/a_object.c +403 -0
  128. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/a_octet.c +71 -0
  129. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/a_print.c +127 -0
  130. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/a_set.c +241 -0
  131. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/a_sign.c +333 -0
  132. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/a_strex.c +574 -0
  133. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/a_strnid.c +290 -0
  134. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/a_time.c +198 -0
  135. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/a_type.c +159 -0
  136. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/a_utctm.c +318 -0
  137. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/a_utf8.c +211 -0
  138. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/a_verify.c +228 -0
  139. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/ameth_lib.c +460 -0
  140. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/asn1.h +1404 -0
  141. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/asn1_err.c +332 -0
  142. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/asn1_gen.c +854 -0
  143. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/asn1_lib.c +482 -0
  144. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/asn1_locl.h +145 -0
  145. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/asn1_mac.h +578 -0
  146. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/asn1_par.c +437 -0
  147. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/asn1t.h +960 -0
  148. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/asn_mime.c +951 -0
  149. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/asn_moid.c +160 -0
  150. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/asn_pack.c +191 -0
  151. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/bio_asn1.c +495 -0
  152. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/bio_ndef.c +243 -0
  153. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/charmap.h +15 -0
  154. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/d2i_pr.c +170 -0
  155. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/d2i_pu.c +139 -0
  156. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/evp_asn1.c +189 -0
  157. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/f_enum.c +207 -0
  158. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/f_int.c +219 -0
  159. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/f_string.c +212 -0
  160. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/i2d_pr.c +80 -0
  161. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/i2d_pu.c +95 -0
  162. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/n_pkey.c +357 -0
  163. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/nsseq.c +83 -0
  164. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/p5_pbe.c +148 -0
  165. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/p5_pbev2.c +280 -0
  166. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/p8_pkey.c +155 -0
  167. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/t_bitst.c +102 -0
  168. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/t_crl.c +132 -0
  169. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/t_pkey.c +114 -0
  170. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/t_req.c +266 -0
  171. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/t_spki.c +107 -0
  172. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/t_x509.c +528 -0
  173. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/t_x509a.c +110 -0
  174. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/tasn_dec.c +1347 -0
  175. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/tasn_enc.c +691 -0
  176. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/tasn_fre.c +266 -0
  177. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/tasn_new.c +396 -0
  178. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/tasn_prn.c +627 -0
  179. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/tasn_typ.c +148 -0
  180. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/tasn_utl.c +279 -0
  181. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/x_algor.c +144 -0
  182. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/x_attrib.c +118 -0
  183. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/x_bignum.c +139 -0
  184. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/x_crl.c +527 -0
  185. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/x_exten.c +76 -0
  186. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/x_info.c +114 -0
  187. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/x_long.c +179 -0
  188. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/x_name.c +519 -0
  189. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/x_nx509.c +72 -0
  190. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/x_pkey.c +151 -0
  191. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/x_pubkey.c +382 -0
  192. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/x_req.c +113 -0
  193. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/x_sig.c +69 -0
  194. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/x_spki.c +81 -0
  195. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/x_val.c +69 -0
  196. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/x_x509.c +194 -0
  197. data/lib/extensions/openssl.so/ext/sources/crypto/asn1/x_x509a.c +180 -0
  198. data/lib/extensions/openssl.so/ext/sources/crypto/bf/bf_cfb64.c +121 -0
  199. data/lib/extensions/openssl.so/ext/sources/crypto/bf/bf_ecb.c +96 -0
  200. data/lib/extensions/openssl.so/ext/sources/crypto/bf/bf_enc.c +306 -0
  201. data/lib/extensions/openssl.so/ext/sources/crypto/bf/bf_locl.h +219 -0
  202. data/lib/extensions/openssl.so/ext/sources/crypto/bf/bf_ofb64.c +110 -0
  203. data/lib/extensions/openssl.so/ext/sources/crypto/bf/bf_pi.h +325 -0
  204. data/lib/extensions/openssl.so/ext/sources/crypto/bf/bf_skey.c +124 -0
  205. data/lib/extensions/openssl.so/ext/sources/crypto/bf/blowfish.h +129 -0
  206. data/lib/extensions/openssl.so/ext/sources/crypto/bio/b_dump.c +187 -0
  207. data/lib/extensions/openssl.so/ext/sources/crypto/bio/b_print.c +842 -0
  208. data/lib/extensions/openssl.so/ext/sources/crypto/bio/b_sock.c +975 -0
  209. data/lib/extensions/openssl.so/ext/sources/crypto/bio/bf_buff.c +512 -0
  210. data/lib/extensions/openssl.so/ext/sources/crypto/bio/bf_nbio.c +253 -0
  211. data/lib/extensions/openssl.so/ext/sources/crypto/bio/bf_null.c +183 -0
  212. data/lib/extensions/openssl.so/ext/sources/crypto/bio/bio.h +847 -0
  213. data/lib/extensions/openssl.so/ext/sources/crypto/bio/bio_cb.c +143 -0
  214. data/lib/extensions/openssl.so/ext/sources/crypto/bio/bio_err.c +155 -0
  215. data/lib/extensions/openssl.so/ext/sources/crypto/bio/bio_lcl.h +36 -0
  216. data/lib/extensions/openssl.so/ext/sources/crypto/bio/bio_lib.c +602 -0
  217. data/lib/extensions/openssl.so/ext/sources/crypto/bio/bss_acpt.c +478 -0
  218. data/lib/extensions/openssl.so/ext/sources/crypto/bio/bss_bio.c +924 -0
  219. data/lib/extensions/openssl.so/ext/sources/crypto/bio/bss_conn.c +652 -0
  220. data/lib/extensions/openssl.so/ext/sources/crypto/bio/bss_dgram.c +1832 -0
  221. data/lib/extensions/openssl.so/ext/sources/crypto/bio/bss_fd.c +319 -0
  222. data/lib/extensions/openssl.so/ext/sources/crypto/bio/bss_file.c +477 -0
  223. data/lib/extensions/openssl.so/ext/sources/crypto/bio/bss_log.c +399 -0
  224. data/lib/extensions/openssl.so/ext/sources/crypto/bio/bss_mem.c +319 -0
  225. data/lib/extensions/openssl.so/ext/sources/crypto/bio/bss_null.c +150 -0
  226. data/lib/extensions/openssl.so/ext/sources/crypto/bio/bss_sock.c +294 -0
  227. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn.h +891 -0
  228. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_add.c +313 -0
  229. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_asm.c +1030 -0
  230. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_blind.c +385 -0
  231. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_const.c +402 -0
  232. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_ctx.c +454 -0
  233. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_depr.c +112 -0
  234. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_div.c +446 -0
  235. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_err.c +150 -0
  236. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_exp.c +1097 -0
  237. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_exp2.c +312 -0
  238. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_gcd.c +654 -0
  239. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_gf2m.c +1113 -0
  240. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_kron.c +184 -0
  241. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_lcl.h +508 -0
  242. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_lib.c +826 -0
  243. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_mod.c +301 -0
  244. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_mont.c +509 -0
  245. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_mpi.c +130 -0
  246. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_mul.c +1166 -0
  247. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_nist.c +1102 -0
  248. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_prime.c +494 -0
  249. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_prime.h +327 -0
  250. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_print.c +378 -0
  251. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_rand.c +305 -0
  252. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_recp.c +234 -0
  253. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_shift.c +223 -0
  254. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_sqr.c +294 -0
  255. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_sqrt.c +393 -0
  256. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_word.c +247 -0
  257. data/lib/extensions/openssl.so/ext/sources/crypto/bn/bn_x931p.c +272 -0
  258. data/lib/extensions/openssl.so/ext/sources/crypto/buffer/buf_err.c +99 -0
  259. data/lib/extensions/openssl.so/ext/sources/crypto/buffer/buf_str.c +119 -0
  260. data/lib/extensions/openssl.so/ext/sources/crypto/buffer/buffer.c +203 -0
  261. data/lib/extensions/openssl.so/ext/sources/crypto/buffer/buffer.h +119 -0
  262. data/lib/extensions/openssl.so/ext/sources/crypto/buildinf.h +12 -0
  263. data/lib/extensions/openssl.so/ext/sources/crypto/camellia/camellia.c +582 -0
  264. data/lib/extensions/openssl.so/ext/sources/crypto/camellia/camellia.h +130 -0
  265. data/lib/extensions/openssl.so/ext/sources/crypto/camellia/cmll_cbc.c +64 -0
  266. data/lib/extensions/openssl.so/ext/sources/crypto/camellia/cmll_cfb.c +139 -0
  267. data/lib/extensions/openssl.so/ext/sources/crypto/camellia/cmll_ctr.c +64 -0
  268. data/lib/extensions/openssl.so/ext/sources/crypto/camellia/cmll_ecb.c +74 -0
  269. data/lib/extensions/openssl.so/ext/sources/crypto/camellia/cmll_locl.h +86 -0
  270. data/lib/extensions/openssl.so/ext/sources/crypto/camellia/cmll_misc.c +80 -0
  271. data/lib/extensions/openssl.so/ext/sources/crypto/camellia/cmll_ofb.c +119 -0
  272. data/lib/extensions/openssl.so/ext/sources/crypto/camellia/cmll_utl.c +64 -0
  273. data/lib/extensions/openssl.so/ext/sources/crypto/cast/c_cfb64.c +121 -0
  274. data/lib/extensions/openssl.so/ext/sources/crypto/cast/c_ecb.c +79 -0
  275. data/lib/extensions/openssl.so/ext/sources/crypto/cast/c_enc.c +208 -0
  276. data/lib/extensions/openssl.so/ext/sources/crypto/cast/c_ofb64.c +110 -0
  277. data/lib/extensions/openssl.so/ext/sources/crypto/cast/c_skey.c +173 -0
  278. data/lib/extensions/openssl.so/ext/sources/crypto/cast/cast.h +107 -0
  279. data/lib/extensions/openssl.so/ext/sources/crypto/cast/cast_lcl.h +227 -0
  280. data/lib/extensions/openssl.so/ext/sources/crypto/cast/cast_s.h +585 -0
  281. data/lib/extensions/openssl.so/ext/sources/crypto/cmac/cm_ameth.c +97 -0
  282. data/lib/extensions/openssl.so/ext/sources/crypto/cmac/cm_pmeth.c +224 -0
  283. data/lib/extensions/openssl.so/ext/sources/crypto/cmac/cmac.c +308 -0
  284. data/lib/extensions/openssl.so/ext/sources/crypto/cmac/cmac.h +82 -0
  285. data/lib/extensions/openssl.so/ext/sources/crypto/cms/cms.h +501 -0
  286. data/lib/extensions/openssl.so/ext/sources/crypto/cms/cms_asn1.c +389 -0
  287. data/lib/extensions/openssl.so/ext/sources/crypto/cms/cms_att.c +195 -0
  288. data/lib/extensions/openssl.so/ext/sources/crypto/cms/cms_cd.c +134 -0
  289. data/lib/extensions/openssl.so/ext/sources/crypto/cms/cms_dd.c +148 -0
  290. data/lib/extensions/openssl.so/ext/sources/crypto/cms/cms_enc.c +294 -0
  291. data/lib/extensions/openssl.so/ext/sources/crypto/cms/cms_env.c +876 -0
  292. data/lib/extensions/openssl.so/ext/sources/crypto/cms/cms_err.c +245 -0
  293. data/lib/extensions/openssl.so/ext/sources/crypto/cms/cms_ess.c +420 -0
  294. data/lib/extensions/openssl.so/ext/sources/crypto/cms/cms_io.c +133 -0
  295. data/lib/extensions/openssl.so/ext/sources/crypto/cms/cms_lcl.h +473 -0
  296. data/lib/extensions/openssl.so/ext/sources/crypto/cms/cms_lib.c +626 -0
  297. data/lib/extensions/openssl.so/ext/sources/crypto/cms/cms_pwri.c +454 -0
  298. data/lib/extensions/openssl.so/ext/sources/crypto/cms/cms_sd.c +985 -0
  299. data/lib/extensions/openssl.so/ext/sources/crypto/cms/cms_smime.c +850 -0
  300. data/lib/extensions/openssl.so/ext/sources/crypto/comp/c_rle.c +61 -0
  301. data/lib/extensions/openssl.so/ext/sources/crypto/comp/c_zlib.c +799 -0
  302. data/lib/extensions/openssl.so/ext/sources/crypto/comp/comp.h +80 -0
  303. data/lib/extensions/openssl.so/ext/sources/crypto/comp/comp_err.c +100 -0
  304. data/lib/extensions/openssl.so/ext/sources/crypto/comp/comp_lib.c +72 -0
  305. data/lib/extensions/openssl.so/ext/sources/crypto/conf/conf.h +263 -0
  306. data/lib/extensions/openssl.so/ext/sources/crypto/conf/conf_api.c +301 -0
  307. data/lib/extensions/openssl.so/ext/sources/crypto/conf/conf_api.h +89 -0
  308. data/lib/extensions/openssl.so/ext/sources/crypto/conf/conf_def.c +740 -0
  309. data/lib/extensions/openssl.so/ext/sources/crypto/conf/conf_def.h +180 -0
  310. data/lib/extensions/openssl.so/ext/sources/crypto/conf/conf_err.c +131 -0
  311. data/lib/extensions/openssl.so/ext/sources/crypto/conf/conf_lib.c +407 -0
  312. data/lib/extensions/openssl.so/ext/sources/crypto/conf/conf_mall.c +80 -0
  313. data/lib/extensions/openssl.so/ext/sources/crypto/conf/conf_mod.c +623 -0
  314. data/lib/extensions/openssl.so/ext/sources/crypto/conf/conf_sap.c +111 -0
  315. data/lib/extensions/openssl.so/ext/sources/crypto/cpt_err.c +105 -0
  316. data/lib/extensions/openssl.so/ext/sources/crypto/cryptlib.c +926 -0
  317. data/lib/extensions/openssl.so/ext/sources/crypto/cryptlib.h +111 -0
  318. data/lib/extensions/openssl.so/ext/sources/crypto/crypto.h +604 -0
  319. data/lib/extensions/openssl.so/ext/sources/crypto/cversion.c +117 -0
  320. data/lib/extensions/openssl.so/ext/sources/crypto/des/cbc_cksm.c +106 -0
  321. data/lib/extensions/openssl.so/ext/sources/crypto/des/cbc_enc.c +61 -0
  322. data/lib/extensions/openssl.so/ext/sources/crypto/des/cfb64ede.c +254 -0
  323. data/lib/extensions/openssl.so/ext/sources/crypto/des/cfb64enc.c +121 -0
  324. data/lib/extensions/openssl.so/ext/sources/crypto/des/cfb_enc.c +195 -0
  325. data/lib/extensions/openssl.so/ext/sources/crypto/des/des.h +248 -0
  326. data/lib/extensions/openssl.so/ext/sources/crypto/des/des_enc.c +400 -0
  327. data/lib/extensions/openssl.so/ext/sources/crypto/des/des_locl.h +432 -0
  328. data/lib/extensions/openssl.so/ext/sources/crypto/des/des_old.c +273 -0
  329. data/lib/extensions/openssl.so/ext/sources/crypto/des/des_old.h +446 -0
  330. data/lib/extensions/openssl.so/ext/sources/crypto/des/des_old2.c +82 -0
  331. data/lib/extensions/openssl.so/ext/sources/crypto/des/des_ver.h +71 -0
  332. data/lib/extensions/openssl.so/ext/sources/crypto/des/ecb3_enc.c +83 -0
  333. data/lib/extensions/openssl.so/ext/sources/crypto/des/ecb_enc.c +122 -0
  334. data/lib/extensions/openssl.so/ext/sources/crypto/des/ede_cbcm_enc.c +199 -0
  335. data/lib/extensions/openssl.so/ext/sources/crypto/des/enc_read.c +240 -0
  336. data/lib/extensions/openssl.so/ext/sources/crypto/des/enc_writ.c +179 -0
  337. data/lib/extensions/openssl.so/ext/sources/crypto/des/fcrypt.c +170 -0
  338. data/lib/extensions/openssl.so/ext/sources/crypto/des/fcrypt_b.c +143 -0
  339. data/lib/extensions/openssl.so/ext/sources/crypto/des/ncbc_enc.c +148 -0
  340. data/lib/extensions/openssl.so/ext/sources/crypto/des/ofb64ede.c +125 -0
  341. data/lib/extensions/openssl.so/ext/sources/crypto/des/ofb64enc.c +110 -0
  342. data/lib/extensions/openssl.so/ext/sources/crypto/des/ofb_enc.c +135 -0
  343. data/lib/extensions/openssl.so/ext/sources/crypto/des/pcbc_enc.c +123 -0
  344. data/lib/extensions/openssl.so/ext/sources/crypto/des/qud_cksm.c +139 -0
  345. data/lib/extensions/openssl.so/ext/sources/crypto/des/rand_key.c +68 -0
  346. data/lib/extensions/openssl.so/ext/sources/crypto/des/read2pwd.c +140 -0
  347. data/lib/extensions/openssl.so/ext/sources/crypto/des/rpc_des.h +131 -0
  348. data/lib/extensions/openssl.so/ext/sources/crypto/des/rpc_enc.c +98 -0
  349. data/lib/extensions/openssl.so/ext/sources/crypto/des/set_key.c +416 -0
  350. data/lib/extensions/openssl.so/ext/sources/crypto/des/spr.h +204 -0
  351. data/lib/extensions/openssl.so/ext/sources/crypto/des/str2key.c +174 -0
  352. data/lib/extensions/openssl.so/ext/sources/crypto/des/xcbc_enc.c +197 -0
  353. data/lib/extensions/openssl.so/ext/sources/crypto/dh/dh.h +280 -0
  354. data/lib/extensions/openssl.so/ext/sources/crypto/dh/dh_ameth.c +501 -0
  355. data/lib/extensions/openssl.so/ext/sources/crypto/dh/dh_asn1.c +93 -0
  356. data/lib/extensions/openssl.so/ext/sources/crypto/dh/dh_check.c +142 -0
  357. data/lib/extensions/openssl.so/ext/sources/crypto/dh/dh_depr.c +83 -0
  358. data/lib/extensions/openssl.so/ext/sources/crypto/dh/dh_err.c +122 -0
  359. data/lib/extensions/openssl.so/ext/sources/crypto/dh/dh_gen.c +192 -0
  360. data/lib/extensions/openssl.so/ext/sources/crypto/dh/dh_key.c +292 -0
  361. data/lib/extensions/openssl.so/ext/sources/crypto/dh/dh_lib.c +260 -0
  362. data/lib/extensions/openssl.so/ext/sources/crypto/dh/dh_pmeth.c +254 -0
  363. data/lib/extensions/openssl.so/ext/sources/crypto/dh/dh_prn.c +80 -0
  364. data/lib/extensions/openssl.so/ext/sources/crypto/dsa/dsa.h +327 -0
  365. data/lib/extensions/openssl.so/ext/sources/crypto/dsa/dsa_ameth.c +704 -0
  366. data/lib/extensions/openssl.so/ext/sources/crypto/dsa/dsa_asn1.c +188 -0
  367. data/lib/extensions/openssl.so/ext/sources/crypto/dsa/dsa_depr.c +106 -0
  368. data/lib/extensions/openssl.so/ext/sources/crypto/dsa/dsa_err.c +130 -0
  369. data/lib/extensions/openssl.so/ext/sources/crypto/dsa/dsa_gen.c +371 -0
  370. data/lib/extensions/openssl.so/ext/sources/crypto/dsa/dsa_key.c +144 -0
  371. data/lib/extensions/openssl.so/ext/sources/crypto/dsa/dsa_lib.c +329 -0
  372. data/lib/extensions/openssl.so/ext/sources/crypto/dsa/dsa_locl.h +60 -0
  373. data/lib/extensions/openssl.so/ext/sources/crypto/dsa/dsa_ossl.c +412 -0
  374. data/lib/extensions/openssl.so/ext/sources/crypto/dsa/dsa_pmeth.c +318 -0
  375. data/lib/extensions/openssl.so/ext/sources/crypto/dsa/dsa_prn.c +121 -0
  376. data/lib/extensions/openssl.so/ext/sources/crypto/dsa/dsa_sign.c +114 -0
  377. data/lib/extensions/openssl.so/ext/sources/crypto/dsa/dsa_vrf.c +76 -0
  378. data/lib/extensions/openssl.so/ext/sources/crypto/dso/dso.h +409 -0
  379. data/lib/extensions/openssl.so/ext/sources/crypto/dso/dso_beos.c +270 -0
  380. data/lib/extensions/openssl.so/ext/sources/crypto/dso/dso_dl.c +393 -0
  381. data/lib/extensions/openssl.so/ext/sources/crypto/dso/dso_dlfcn.c +484 -0
  382. data/lib/extensions/openssl.so/ext/sources/crypto/dso/dso_err.c +159 -0
  383. data/lib/extensions/openssl.so/ext/sources/crypto/dso/dso_lib.c +483 -0
  384. data/lib/extensions/openssl.so/ext/sources/crypto/dso/dso_null.c +90 -0
  385. data/lib/extensions/openssl.so/ext/sources/crypto/dso/dso_openssl.c +83 -0
  386. data/lib/extensions/openssl.so/ext/sources/crypto/dso/dso_vms.c +525 -0
  387. data/lib/extensions/openssl.so/ext/sources/crypto/dso/dso_win32.c +844 -0
  388. data/lib/extensions/openssl.so/ext/sources/crypto/ebcdic.c +221 -0
  389. data/lib/extensions/openssl.so/ext/sources/crypto/ebcdic.h +19 -0
  390. data/lib/extensions/openssl.so/ext/sources/crypto/ec/ec.h +1159 -0
  391. data/lib/extensions/openssl.so/ext/sources/crypto/ec/ec2_mult.c +390 -0
  392. data/lib/extensions/openssl.so/ext/sources/crypto/ec/ec2_oct.c +407 -0
  393. data/lib/extensions/openssl.so/ext/sources/crypto/ec/ec2_smpl.c +719 -0
  394. data/lib/extensions/openssl.so/ext/sources/crypto/ec/ec_ameth.c +660 -0
  395. data/lib/extensions/openssl.so/ext/sources/crypto/ec/ec_asn1.c +1447 -0
  396. data/lib/extensions/openssl.so/ext/sources/crypto/ec/ec_check.c +123 -0
  397. data/lib/extensions/openssl.so/ext/sources/crypto/ec/ec_curve.c +2100 -0
  398. data/lib/extensions/openssl.so/ext/sources/crypto/ec/ec_cvt.c +170 -0
  399. data/lib/extensions/openssl.so/ext/sources/crypto/ec/ec_err.c +276 -0
  400. data/lib/extensions/openssl.so/ext/sources/crypto/ec/ec_key.c +563 -0
  401. data/lib/extensions/openssl.so/ext/sources/crypto/ec/ec_lcl.h +446 -0
  402. data/lib/extensions/openssl.so/ext/sources/crypto/ec/ec_lib.c +1096 -0
  403. data/lib/extensions/openssl.so/ext/sources/crypto/ec/ec_mult.c +940 -0
  404. data/lib/extensions/openssl.so/ext/sources/crypto/ec/ec_oct.c +199 -0
  405. data/lib/extensions/openssl.so/ext/sources/crypto/ec/ec_pmeth.c +341 -0
  406. data/lib/extensions/openssl.so/ext/sources/crypto/ec/ec_print.c +195 -0
  407. data/lib/extensions/openssl.so/ext/sources/crypto/ec/eck_prn.c +392 -0
  408. data/lib/extensions/openssl.so/ext/sources/crypto/ec/ecp_mont.c +323 -0
  409. data/lib/extensions/openssl.so/ext/sources/crypto/ec/ecp_nist.c +217 -0
  410. data/lib/extensions/openssl.so/ext/sources/crypto/ec/ecp_nistp224.c +1658 -0
  411. data/lib/extensions/openssl.so/ext/sources/crypto/ec/ecp_nistp256.c +2171 -0
  412. data/lib/extensions/openssl.so/ext/sources/crypto/ec/ecp_nistp521.c +2025 -0
  413. data/lib/extensions/openssl.so/ext/sources/crypto/ec/ecp_nistputil.c +197 -0
  414. data/lib/extensions/openssl.so/ext/sources/crypto/ec/ecp_oct.c +433 -0
  415. data/lib/extensions/openssl.so/ext/sources/crypto/ec/ecp_smpl.c +1360 -0
  416. data/lib/extensions/openssl.so/ext/sources/crypto/ecdh/ecdh.h +125 -0
  417. data/lib/extensions/openssl.so/ext/sources/crypto/ecdh/ech_err.c +100 -0
  418. data/lib/extensions/openssl.so/ext/sources/crypto/ecdh/ech_key.c +83 -0
  419. data/lib/extensions/openssl.so/ext/sources/crypto/ecdh/ech_lib.c +266 -0
  420. data/lib/extensions/openssl.so/ext/sources/crypto/ecdh/ech_locl.h +102 -0
  421. data/lib/extensions/openssl.so/ext/sources/crypto/ecdh/ech_ossl.c +215 -0
  422. data/lib/extensions/openssl.so/ext/sources/crypto/ecdsa/ecdsa.h +260 -0
  423. data/lib/extensions/openssl.so/ext/sources/crypto/ecdsa/ecs_asn1.c +69 -0
  424. data/lib/extensions/openssl.so/ext/sources/crypto/ecdsa/ecs_err.c +106 -0
  425. data/lib/extensions/openssl.so/ext/sources/crypto/ecdsa/ecs_lib.c +278 -0
  426. data/lib/extensions/openssl.so/ext/sources/crypto/ecdsa/ecs_locl.h +115 -0
  427. data/lib/extensions/openssl.so/ext/sources/crypto/ecdsa/ecs_ossl.c +483 -0
  428. data/lib/extensions/openssl.so/ext/sources/crypto/ecdsa/ecs_sign.c +106 -0
  429. data/lib/extensions/openssl.so/ext/sources/crypto/ecdsa/ecs_vrf.c +96 -0
  430. data/lib/extensions/openssl.so/ext/sources/crypto/engine/eng_all.c +135 -0
  431. data/lib/extensions/openssl.so/ext/sources/crypto/engine/eng_cnf.c +259 -0
  432. data/lib/extensions/openssl.so/ext/sources/crypto/engine/eng_cryptodev.c +1450 -0
  433. data/lib/extensions/openssl.so/ext/sources/crypto/engine/eng_ctrl.c +389 -0
  434. data/lib/extensions/openssl.so/ext/sources/crypto/engine/eng_dyn.c +548 -0
  435. data/lib/extensions/openssl.so/ext/sources/crypto/engine/eng_err.c +173 -0
  436. data/lib/extensions/openssl.so/ext/sources/crypto/engine/eng_fat.c +182 -0
  437. data/lib/extensions/openssl.so/ext/sources/crypto/engine/eng_init.c +154 -0
  438. data/lib/extensions/openssl.so/ext/sources/crypto/engine/eng_int.h +206 -0
  439. data/lib/extensions/openssl.so/ext/sources/crypto/engine/eng_lib.c +332 -0
  440. data/lib/extensions/openssl.so/ext/sources/crypto/engine/eng_list.c +433 -0
  441. data/lib/extensions/openssl.so/ext/sources/crypto/engine/eng_openssl.c +384 -0
  442. data/lib/extensions/openssl.so/ext/sources/crypto/engine/eng_pkey.c +196 -0
  443. data/lib/extensions/openssl.so/ext/sources/crypto/engine/eng_rdrand.c +142 -0
  444. data/lib/extensions/openssl.so/ext/sources/crypto/engine/eng_rsax.c +668 -0
  445. data/lib/extensions/openssl.so/ext/sources/crypto/engine/eng_table.c +351 -0
  446. data/lib/extensions/openssl.so/ext/sources/crypto/engine/engine.h +842 -0
  447. data/lib/extensions/openssl.so/ext/sources/crypto/engine/tb_asnmth.c +246 -0
  448. data/lib/extensions/openssl.so/ext/sources/crypto/engine/tb_cipher.c +143 -0
  449. data/lib/extensions/openssl.so/ext/sources/crypto/engine/tb_dh.c +118 -0
  450. data/lib/extensions/openssl.so/ext/sources/crypto/engine/tb_digest.c +143 -0
  451. data/lib/extensions/openssl.so/ext/sources/crypto/engine/tb_dsa.c +118 -0
  452. data/lib/extensions/openssl.so/ext/sources/crypto/engine/tb_ecdh.c +133 -0
  453. data/lib/extensions/openssl.so/ext/sources/crypto/engine/tb_ecdsa.c +118 -0
  454. data/lib/extensions/openssl.so/ext/sources/crypto/engine/tb_pkmeth.c +167 -0
  455. data/lib/extensions/openssl.so/ext/sources/crypto/engine/tb_rand.c +118 -0
  456. data/lib/extensions/openssl.so/ext/sources/crypto/engine/tb_rsa.c +118 -0
  457. data/lib/extensions/openssl.so/ext/sources/crypto/engine/tb_store.c +123 -0
  458. data/lib/extensions/openssl.so/ext/sources/crypto/err/err.c +1138 -0
  459. data/lib/extensions/openssl.so/ext/sources/crypto/err/err.h +386 -0
  460. data/lib/extensions/openssl.so/ext/sources/crypto/err/err_all.c +167 -0
  461. data/lib/extensions/openssl.so/ext/sources/crypto/err/err_prn.c +114 -0
  462. data/lib/extensions/openssl.so/ext/sources/crypto/evp/bio_b64.c +598 -0
  463. data/lib/extensions/openssl.so/ext/sources/crypto/evp/bio_enc.c +428 -0
  464. data/lib/extensions/openssl.so/ext/sources/crypto/evp/bio_md.c +275 -0
  465. data/lib/extensions/openssl.so/ext/sources/crypto/evp/bio_ok.c +624 -0
  466. data/lib/extensions/openssl.so/ext/sources/crypto/evp/c_all.c +90 -0
  467. data/lib/extensions/openssl.so/ext/sources/crypto/evp/c_allc.c +230 -0
  468. data/lib/extensions/openssl.so/ext/sources/crypto/evp/c_alld.c +114 -0
  469. data/lib/extensions/openssl.so/ext/sources/crypto/evp/digest.c +403 -0
  470. data/lib/extensions/openssl.so/ext/sources/crypto/evp/e_aes.c +1313 -0
  471. data/lib/extensions/openssl.so/ext/sources/crypto/evp/e_aes_cbc_hmac_sha1.c +406 -0
  472. data/lib/extensions/openssl.so/ext/sources/crypto/evp/e_bf.c +88 -0
  473. data/lib/extensions/openssl.so/ext/sources/crypto/evp/e_camellia.c +131 -0
  474. data/lib/extensions/openssl.so/ext/sources/crypto/evp/e_cast.c +90 -0
  475. data/lib/extensions/openssl.so/ext/sources/crypto/evp/e_des.c +224 -0
  476. data/lib/extensions/openssl.so/ext/sources/crypto/evp/e_des3.c +316 -0
  477. data/lib/extensions/openssl.so/ext/sources/crypto/evp/e_idea.c +118 -0
  478. data/lib/extensions/openssl.so/ext/sources/crypto/evp/e_null.c +104 -0
  479. data/lib/extensions/openssl.so/ext/sources/crypto/evp/e_old.c +125 -0
  480. data/lib/extensions/openssl.so/ext/sources/crypto/evp/e_rc2.c +238 -0
  481. data/lib/extensions/openssl.so/ext/sources/crypto/evp/e_rc4.c +137 -0
  482. data/lib/extensions/openssl.so/ext/sources/crypto/evp/e_rc4_hmac_md5.c +298 -0
  483. data/lib/extensions/openssl.so/ext/sources/crypto/evp/e_rc5.c +126 -0
  484. data/lib/extensions/openssl.so/ext/sources/crypto/evp/e_seed.c +83 -0
  485. data/lib/extensions/openssl.so/ext/sources/crypto/evp/e_xcbc_d.c +138 -0
  486. data/lib/extensions/openssl.so/ext/sources/crypto/evp/encode.c +445 -0
  487. data/lib/extensions/openssl.so/ext/sources/crypto/evp/evp.h +1402 -0
  488. data/lib/extensions/openssl.so/ext/sources/crypto/evp/evp_acnf.c +73 -0
  489. data/lib/extensions/openssl.so/ext/sources/crypto/evp/evp_enc.c +681 -0
  490. data/lib/extensions/openssl.so/ext/sources/crypto/evp/evp_err.c +234 -0
  491. data/lib/extensions/openssl.so/ext/sources/crypto/evp/evp_fips.c +113 -0
  492. data/lib/extensions/openssl.so/ext/sources/crypto/evp/evp_key.c +189 -0
  493. data/lib/extensions/openssl.so/ext/sources/crypto/evp/evp_lib.c +316 -0
  494. data/lib/extensions/openssl.so/ext/sources/crypto/evp/evp_locl.h +385 -0
  495. data/lib/extensions/openssl.so/ext/sources/crypto/evp/evp_pbe.c +316 -0
  496. data/lib/extensions/openssl.so/ext/sources/crypto/evp/evp_pkey.c +242 -0
  497. data/lib/extensions/openssl.so/ext/sources/crypto/evp/m_dss.c +101 -0
  498. data/lib/extensions/openssl.so/ext/sources/crypto/evp/m_dss1.c +103 -0
  499. data/lib/extensions/openssl.so/ext/sources/crypto/evp/m_ecdsa.c +151 -0
  500. data/lib/extensions/openssl.so/ext/sources/crypto/evp/m_md4.c +103 -0
  501. data/lib/extensions/openssl.so/ext/sources/crypto/evp/m_md5.c +102 -0
  502. data/lib/extensions/openssl.so/ext/sources/crypto/evp/m_mdc2.c +103 -0
  503. data/lib/extensions/openssl.so/ext/sources/crypto/evp/m_null.c +95 -0
  504. data/lib/extensions/openssl.so/ext/sources/crypto/evp/m_ripemd.c +102 -0
  505. data/lib/extensions/openssl.so/ext/sources/crypto/evp/m_sha.c +101 -0
  506. data/lib/extensions/openssl.so/ext/sources/crypto/evp/m_sha1.c +209 -0
  507. data/lib/extensions/openssl.so/ext/sources/crypto/evp/m_sigver.c +200 -0
  508. data/lib/extensions/openssl.so/ext/sources/crypto/evp/m_wp.c +43 -0
  509. data/lib/extensions/openssl.so/ext/sources/crypto/evp/names.c +206 -0
  510. data/lib/extensions/openssl.so/ext/sources/crypto/evp/p5_crpt.c +143 -0
  511. data/lib/extensions/openssl.so/ext/sources/crypto/evp/p5_crpt2.c +322 -0
  512. data/lib/extensions/openssl.so/ext/sources/crypto/evp/p_dec.c +87 -0
  513. data/lib/extensions/openssl.so/ext/sources/crypto/evp/p_enc.c +86 -0
  514. data/lib/extensions/openssl.so/ext/sources/crypto/evp/p_lib.c +469 -0
  515. data/lib/extensions/openssl.so/ext/sources/crypto/evp/p_open.c +128 -0
  516. data/lib/extensions/openssl.so/ext/sources/crypto/evp/p_seal.c +116 -0
  517. data/lib/extensions/openssl.so/ext/sources/crypto/evp/p_sign.c +139 -0
  518. data/lib/extensions/openssl.so/ext/sources/crypto/evp/p_verify.c +121 -0
  519. data/lib/extensions/openssl.so/ext/sources/crypto/evp/pmeth_fn.c +368 -0
  520. data/lib/extensions/openssl.so/ext/sources/crypto/evp/pmeth_gn.c +221 -0
  521. data/lib/extensions/openssl.so/ext/sources/crypto/evp/pmeth_lib.c +593 -0
  522. data/lib/extensions/openssl.so/ext/sources/crypto/ex_data.c +636 -0
  523. data/lib/extensions/openssl.so/ext/sources/crypto/fips_err.h +209 -0
  524. data/lib/extensions/openssl.so/ext/sources/crypto/fips_ers.c +7 -0
  525. data/lib/extensions/openssl.so/ext/sources/crypto/hmac/hm_ameth.c +167 -0
  526. data/lib/extensions/openssl.so/ext/sources/crypto/hmac/hm_pmeth.c +271 -0
  527. data/lib/extensions/openssl.so/ext/sources/crypto/hmac/hmac.c +251 -0
  528. data/lib/extensions/openssl.so/ext/sources/crypto/hmac/hmac.h +110 -0
  529. data/lib/extensions/openssl.so/ext/sources/crypto/idea/i_cbc.c +168 -0
  530. data/lib/extensions/openssl.so/ext/sources/crypto/idea/i_cfb64.c +122 -0
  531. data/lib/extensions/openssl.so/ext/sources/crypto/idea/i_ecb.c +85 -0
  532. data/lib/extensions/openssl.so/ext/sources/crypto/idea/i_ofb64.c +111 -0
  533. data/lib/extensions/openssl.so/ext/sources/crypto/idea/i_skey.c +164 -0
  534. data/lib/extensions/openssl.so/ext/sources/crypto/idea/idea.h +103 -0
  535. data/lib/extensions/openssl.so/ext/sources/crypto/idea/idea_lcl.h +215 -0
  536. data/lib/extensions/openssl.so/ext/sources/crypto/krb5/krb5_asn.c +167 -0
  537. data/lib/extensions/openssl.so/ext/sources/crypto/krb5/krb5_asn.h +256 -0
  538. data/lib/extensions/openssl.so/ext/sources/crypto/lhash/lh_stats.c +248 -0
  539. data/lib/extensions/openssl.so/ext/sources/crypto/lhash/lhash.c +475 -0
  540. data/lib/extensions/openssl.so/ext/sources/crypto/lhash/lhash.h +241 -0
  541. data/lib/extensions/openssl.so/ext/sources/crypto/md32_common.h +415 -0
  542. data/lib/extensions/openssl.so/ext/sources/crypto/md4/md4.h +120 -0
  543. data/lib/extensions/openssl.so/ext/sources/crypto/md4/md4_dgst.c +168 -0
  544. data/lib/extensions/openssl.so/ext/sources/crypto/md4/md4_locl.h +112 -0
  545. data/lib/extensions/openssl.so/ext/sources/crypto/md4/md4_one.c +97 -0
  546. data/lib/extensions/openssl.so/ext/sources/crypto/md5/md5.h +120 -0
  547. data/lib/extensions/openssl.so/ext/sources/crypto/md5/md5_dgst.c +185 -0
  548. data/lib/extensions/openssl.so/ext/sources/crypto/md5/md5_locl.h +130 -0
  549. data/lib/extensions/openssl.so/ext/sources/crypto/md5/md5_one.c +97 -0
  550. data/lib/extensions/openssl.so/ext/sources/crypto/mdc2/mdc2.h +98 -0
  551. data/lib/extensions/openssl.so/ext/sources/crypto/mdc2/mdc2_one.c +76 -0
  552. data/lib/extensions/openssl.so/ext/sources/crypto/mdc2/mdc2dgst.c +200 -0
  553. data/lib/extensions/openssl.so/ext/sources/crypto/mem.c +420 -0
  554. data/lib/extensions/openssl.so/ext/sources/crypto/mem_clr.c +77 -0
  555. data/lib/extensions/openssl.so/ext/sources/crypto/mem_dbg.c +874 -0
  556. data/lib/extensions/openssl.so/ext/sources/crypto/modes/cbc128.c +202 -0
  557. data/lib/extensions/openssl.so/ext/sources/crypto/modes/ccm128.c +441 -0
  558. data/lib/extensions/openssl.so/ext/sources/crypto/modes/cfb128.c +242 -0
  559. data/lib/extensions/openssl.so/ext/sources/crypto/modes/ctr128.c +252 -0
  560. data/lib/extensions/openssl.so/ext/sources/crypto/modes/cts128.c +465 -0
  561. data/lib/extensions/openssl.so/ext/sources/crypto/modes/gcm128.c +1757 -0
  562. data/lib/extensions/openssl.so/ext/sources/crypto/modes/modes.h +135 -0
  563. data/lib/extensions/openssl.so/ext/sources/crypto/modes/modes_lcl.h +131 -0
  564. data/lib/extensions/openssl.so/ext/sources/crypto/modes/ofb128.c +121 -0
  565. data/lib/extensions/openssl.so/ext/sources/crypto/modes/xts128.c +187 -0
  566. data/lib/extensions/openssl.so/ext/sources/crypto/o_dir.c +83 -0
  567. data/lib/extensions/openssl.so/ext/sources/crypto/o_dir.h +53 -0
  568. data/lib/extensions/openssl.so/ext/sources/crypto/o_fips.c +96 -0
  569. data/lib/extensions/openssl.so/ext/sources/crypto/o_init.c +82 -0
  570. data/lib/extensions/openssl.so/ext/sources/crypto/o_str.c +111 -0
  571. data/lib/extensions/openssl.so/ext/sources/crypto/o_str.h +68 -0
  572. data/lib/extensions/openssl.so/ext/sources/crypto/o_time.c +372 -0
  573. data/lib/extensions/openssl.so/ext/sources/crypto/o_time.h +67 -0
  574. data/lib/extensions/openssl.so/ext/sources/crypto/objects/o_names.c +372 -0
  575. data/lib/extensions/openssl.so/ext/sources/crypto/objects/obj_dat.c +810 -0
  576. data/lib/extensions/openssl.so/ext/sources/crypto/objects/obj_dat.h +5102 -0
  577. data/lib/extensions/openssl.so/ext/sources/crypto/objects/obj_err.c +102 -0
  578. data/lib/extensions/openssl.so/ext/sources/crypto/objects/obj_lib.c +129 -0
  579. data/lib/extensions/openssl.so/ext/sources/crypto/objects/obj_mac.h +4032 -0
  580. data/lib/extensions/openssl.so/ext/sources/crypto/objects/obj_xref.c +234 -0
  581. data/lib/extensions/openssl.so/ext/sources/crypto/objects/obj_xref.h +77 -0
  582. data/lib/extensions/openssl.so/ext/sources/crypto/objects/objects.h +1138 -0
  583. data/lib/extensions/openssl.so/ext/sources/crypto/ocsp/ocsp.h +623 -0
  584. data/lib/extensions/openssl.so/ext/sources/crypto/ocsp/ocsp_asn.c +182 -0
  585. data/lib/extensions/openssl.so/ext/sources/crypto/ocsp/ocsp_cl.c +371 -0
  586. data/lib/extensions/openssl.so/ext/sources/crypto/ocsp/ocsp_err.c +142 -0
  587. data/lib/extensions/openssl.so/ext/sources/crypto/ocsp/ocsp_ext.c +518 -0
  588. data/lib/extensions/openssl.so/ext/sources/crypto/ocsp/ocsp_ht.c +504 -0
  589. data/lib/extensions/openssl.so/ext/sources/crypto/ocsp/ocsp_lib.c +266 -0
  590. data/lib/extensions/openssl.so/ext/sources/crypto/ocsp/ocsp_prn.c +290 -0
  591. data/lib/extensions/openssl.so/ext/sources/crypto/ocsp/ocsp_srv.c +264 -0
  592. data/lib/extensions/openssl.so/ext/sources/crypto/ocsp/ocsp_vfy.c +446 -0
  593. data/lib/extensions/openssl.so/ext/sources/crypto/opensslconf.h +230 -0
  594. data/lib/extensions/openssl.so/ext/sources/crypto/opensslconf.h.in +154 -0
  595. data/lib/extensions/openssl.so/ext/sources/crypto/opensslv.h +89 -0
  596. data/lib/extensions/openssl.so/ext/sources/crypto/ossl_typ.h +202 -0
  597. data/lib/extensions/openssl.so/ext/sources/crypto/pem/pem.h +641 -0
  598. data/lib/extensions/openssl.so/ext/sources/crypto/pem/pem2.h +70 -0
  599. data/lib/extensions/openssl.so/ext/sources/crypto/pem/pem_all.c +296 -0
  600. data/lib/extensions/openssl.so/ext/sources/crypto/pem/pem_err.c +161 -0
  601. data/lib/extensions/openssl.so/ext/sources/crypto/pem/pem_info.c +405 -0
  602. data/lib/extensions/openssl.so/ext/sources/crypto/pem/pem_lib.c +852 -0
  603. data/lib/extensions/openssl.so/ext/sources/crypto/pem/pem_oth.c +86 -0
  604. data/lib/extensions/openssl.so/ext/sources/crypto/pem/pem_pk8.c +242 -0
  605. data/lib/extensions/openssl.so/ext/sources/crypto/pem/pem_pkey.c +242 -0
  606. data/lib/extensions/openssl.so/ext/sources/crypto/pem/pem_seal.c +189 -0
  607. data/lib/extensions/openssl.so/ext/sources/crypto/pem/pem_sign.c +102 -0
  608. data/lib/extensions/openssl.so/ext/sources/crypto/pem/pem_x509.c +68 -0
  609. data/lib/extensions/openssl.so/ext/sources/crypto/pem/pem_xaux.c +68 -0
  610. data/lib/extensions/openssl.so/ext/sources/crypto/pem/pvkfmt.c +950 -0
  611. data/lib/extensions/openssl.so/ext/sources/crypto/pkcs12/p12_add.c +240 -0
  612. data/lib/extensions/openssl.so/ext/sources/crypto/pkcs12/p12_asn.c +125 -0
  613. data/lib/extensions/openssl.so/ext/sources/crypto/pkcs12/p12_attr.c +145 -0
  614. data/lib/extensions/openssl.so/ext/sources/crypto/pkcs12/p12_crpt.c +112 -0
  615. data/lib/extensions/openssl.so/ext/sources/crypto/pkcs12/p12_crt.c +359 -0
  616. data/lib/extensions/openssl.so/ext/sources/crypto/pkcs12/p12_decr.c +184 -0
  617. data/lib/extensions/openssl.so/ext/sources/crypto/pkcs12/p12_init.c +92 -0
  618. data/lib/extensions/openssl.so/ext/sources/crypto/pkcs12/p12_key.c +219 -0
  619. data/lib/extensions/openssl.so/ext/sources/crypto/pkcs12/p12_kiss.c +302 -0
  620. data/lib/extensions/openssl.so/ext/sources/crypto/pkcs12/p12_mutl.c +190 -0
  621. data/lib/extensions/openssl.so/ext/sources/crypto/pkcs12/p12_npas.c +225 -0
  622. data/lib/extensions/openssl.so/ext/sources/crypto/pkcs12/p12_p8d.c +68 -0
  623. data/lib/extensions/openssl.so/ext/sources/crypto/pkcs12/p12_p8e.c +97 -0
  624. data/lib/extensions/openssl.so/ext/sources/crypto/pkcs12/p12_utl.c +146 -0
  625. data/lib/extensions/openssl.so/ext/sources/crypto/pkcs12/pk12err.c +144 -0
  626. data/lib/extensions/openssl.so/ext/sources/crypto/pkcs12/pkcs12.h +331 -0
  627. data/lib/extensions/openssl.so/ext/sources/crypto/pkcs7/bio_pk7.c +69 -0
  628. data/lib/extensions/openssl.so/ext/sources/crypto/pkcs7/pk7_asn1.c +247 -0
  629. data/lib/extensions/openssl.so/ext/sources/crypto/pkcs7/pk7_attr.c +165 -0
  630. data/lib/extensions/openssl.so/ext/sources/crypto/pkcs7/pk7_doit.c +1299 -0
  631. data/lib/extensions/openssl.so/ext/sources/crypto/pkcs7/pk7_lib.c +665 -0
  632. data/lib/extensions/openssl.so/ext/sources/crypto/pkcs7/pk7_mime.c +97 -0
  633. data/lib/extensions/openssl.so/ext/sources/crypto/pkcs7/pk7_smime.c +606 -0
  634. data/lib/extensions/openssl.so/ext/sources/crypto/pkcs7/pkcs7.h +499 -0
  635. data/lib/extensions/openssl.so/ext/sources/crypto/pkcs7/pkcs7err.c +187 -0
  636. data/lib/extensions/openssl.so/ext/sources/crypto/pqueue/pqueue.c +252 -0
  637. data/lib/extensions/openssl.so/ext/sources/crypto/pqueue/pqueue.h +94 -0
  638. data/lib/extensions/openssl.so/ext/sources/crypto/rand/md_rand.c +592 -0
  639. data/lib/extensions/openssl.so/ext/sources/crypto/rand/rand.h +149 -0
  640. data/lib/extensions/openssl.so/ext/sources/crypto/rand/rand_egd.c +303 -0
  641. data/lib/extensions/openssl.so/ext/sources/crypto/rand/rand_err.c +100 -0
  642. data/lib/extensions/openssl.so/ext/sources/crypto/rand/rand_lcl.h +158 -0
  643. data/lib/extensions/openssl.so/ext/sources/crypto/rand/rand_lib.c +295 -0
  644. data/lib/extensions/openssl.so/ext/sources/crypto/rand/rand_nw.c +183 -0
  645. data/lib/extensions/openssl.so/ext/sources/crypto/rand/rand_os2.c +153 -0
  646. data/lib/extensions/openssl.so/ext/sources/crypto/rand/rand_unix.c +431 -0
  647. data/lib/extensions/openssl.so/ext/sources/crypto/rand/rand_win.c +807 -0
  648. data/lib/extensions/openssl.so/ext/sources/crypto/rand/randfile.c +326 -0
  649. data/lib/extensions/openssl.so/ext/sources/crypto/rc2/rc2.h +103 -0
  650. data/lib/extensions/openssl.so/ext/sources/crypto/rc2/rc2_cbc.c +226 -0
  651. data/lib/extensions/openssl.so/ext/sources/crypto/rc2/rc2_ecb.c +88 -0
  652. data/lib/extensions/openssl.so/ext/sources/crypto/rc2/rc2_locl.h +156 -0
  653. data/lib/extensions/openssl.so/ext/sources/crypto/rc2/rc2_skey.c +153 -0
  654. data/lib/extensions/openssl.so/ext/sources/crypto/rc2/rc2cfb64.c +122 -0
  655. data/lib/extensions/openssl.so/ext/sources/crypto/rc2/rc2ofb64.c +111 -0
  656. data/lib/extensions/openssl.so/ext/sources/crypto/rc4/rc4.h +90 -0
  657. data/lib/extensions/openssl.so/ext/sources/crypto/rc4/rc4_enc.c +315 -0
  658. data/lib/extensions/openssl.so/ext/sources/crypto/rc4/rc4_locl.h +5 -0
  659. data/lib/extensions/openssl.so/ext/sources/crypto/rc4/rc4_skey.c +116 -0
  660. data/lib/extensions/openssl.so/ext/sources/crypto/rc4/rc4_utl.c +62 -0
  661. data/lib/extensions/openssl.so/ext/sources/crypto/ripemd/ripemd.h +107 -0
  662. data/lib/extensions/openssl.so/ext/sources/crypto/ripemd/rmd_dgst.c +292 -0
  663. data/lib/extensions/openssl.so/ext/sources/crypto/ripemd/rmd_locl.h +150 -0
  664. data/lib/extensions/openssl.so/ext/sources/crypto/ripemd/rmd_one.c +78 -0
  665. data/lib/extensions/openssl.so/ext/sources/crypto/ripemd/rmdconst.h +399 -0
  666. data/lib/extensions/openssl.so/ext/sources/crypto/rsa/rsa.h +582 -0
  667. data/lib/extensions/openssl.so/ext/sources/crypto/rsa/rsa_ameth.c +698 -0
  668. data/lib/extensions/openssl.so/ext/sources/crypto/rsa/rsa_asn1.c +121 -0
  669. data/lib/extensions/openssl.so/ext/sources/crypto/rsa/rsa_chk.c +184 -0
  670. data/lib/extensions/openssl.so/ext/sources/crypto/rsa/rsa_crpt.c +257 -0
  671. data/lib/extensions/openssl.so/ext/sources/crypto/rsa/rsa_depr.c +101 -0
  672. data/lib/extensions/openssl.so/ext/sources/crypto/rsa/rsa_eay.c +915 -0
  673. data/lib/extensions/openssl.so/ext/sources/crypto/rsa/rsa_err.c +209 -0
  674. data/lib/extensions/openssl.so/ext/sources/crypto/rsa/rsa_gen.c +234 -0
  675. data/lib/extensions/openssl.so/ext/sources/crypto/rsa/rsa_lib.c +333 -0
  676. data/lib/extensions/openssl.so/ext/sources/crypto/rsa/rsa_locl.h +4 -0
  677. data/lib/extensions/openssl.so/ext/sources/crypto/rsa/rsa_none.c +98 -0
  678. data/lib/extensions/openssl.so/ext/sources/crypto/rsa/rsa_null.c +151 -0
  679. data/lib/extensions/openssl.so/ext/sources/crypto/rsa/rsa_oaep.c +235 -0
  680. data/lib/extensions/openssl.so/ext/sources/crypto/rsa/rsa_pk1.c +224 -0
  681. data/lib/extensions/openssl.so/ext/sources/crypto/rsa/rsa_pmeth.c +723 -0
  682. data/lib/extensions/openssl.so/ext/sources/crypto/rsa/rsa_prn.c +93 -0
  683. data/lib/extensions/openssl.so/ext/sources/crypto/rsa/rsa_pss.c +300 -0
  684. data/lib/extensions/openssl.so/ext/sources/crypto/rsa/rsa_saos.c +150 -0
  685. data/lib/extensions/openssl.so/ext/sources/crypto/rsa/rsa_sign.c +318 -0
  686. data/lib/extensions/openssl.so/ext/sources/crypto/rsa/rsa_ssl.c +154 -0
  687. data/lib/extensions/openssl.so/ext/sources/crypto/rsa/rsa_x931.c +177 -0
  688. data/lib/extensions/openssl.so/ext/sources/crypto/seed/seed.c +336 -0
  689. data/lib/extensions/openssl.so/ext/sources/crypto/seed/seed.h +139 -0
  690. data/lib/extensions/openssl.so/ext/sources/crypto/seed/seed_cbc.c +63 -0
  691. data/lib/extensions/openssl.so/ext/sources/crypto/seed/seed_cfb.c +116 -0
  692. data/lib/extensions/openssl.so/ext/sources/crypto/seed/seed_ecb.c +60 -0
  693. data/lib/extensions/openssl.so/ext/sources/crypto/seed/seed_locl.h +116 -0
  694. data/lib/extensions/openssl.so/ext/sources/crypto/seed/seed_ofb.c +116 -0
  695. data/lib/extensions/openssl.so/ext/sources/crypto/sha/sha.h +214 -0
  696. data/lib/extensions/openssl.so/ext/sources/crypto/sha/sha1_one.c +78 -0
  697. data/lib/extensions/openssl.so/ext/sources/crypto/sha/sha1dgst.c +75 -0
  698. data/lib/extensions/openssl.so/ext/sources/crypto/sha/sha256.c +282 -0
  699. data/lib/extensions/openssl.so/ext/sources/crypto/sha/sha512.c +597 -0
  700. data/lib/extensions/openssl.so/ext/sources/crypto/sha/sha_dgst.c +75 -0
  701. data/lib/extensions/openssl.so/ext/sources/crypto/sha/sha_locl.h +441 -0
  702. data/lib/extensions/openssl.so/ext/sources/crypto/sha/sha_one.c +78 -0
  703. data/lib/extensions/openssl.so/ext/sources/crypto/srp/srp.h +172 -0
  704. data/lib/extensions/openssl.so/ext/sources/crypto/srp/srp_grps.h +517 -0
  705. data/lib/extensions/openssl.so/ext/sources/crypto/srp/srp_lcl.h +83 -0
  706. data/lib/extensions/openssl.so/ext/sources/crypto/srp/srp_lib.c +357 -0
  707. data/lib/extensions/openssl.so/ext/sources/crypto/srp/srp_vfy.c +657 -0
  708. data/lib/extensions/openssl.so/ext/sources/crypto/stack/safestack.h +2663 -0
  709. data/lib/extensions/openssl.so/ext/sources/crypto/stack/stack.c +334 -0
  710. data/lib/extensions/openssl.so/ext/sources/crypto/stack/stack.h +108 -0
  711. data/lib/extensions/openssl.so/ext/sources/crypto/symhacks.h +477 -0
  712. data/lib/extensions/openssl.so/ext/sources/crypto/ts/ts.h +858 -0
  713. data/lib/extensions/openssl.so/ext/sources/crypto/ts/ts_asn1.c +322 -0
  714. data/lib/extensions/openssl.so/ext/sources/crypto/ts/ts_conf.c +507 -0
  715. data/lib/extensions/openssl.so/ext/sources/crypto/ts/ts_err.c +179 -0
  716. data/lib/extensions/openssl.so/ext/sources/crypto/ts/ts_lib.c +145 -0
  717. data/lib/extensions/openssl.so/ext/sources/crypto/ts/ts_req_print.c +102 -0
  718. data/lib/extensions/openssl.so/ext/sources/crypto/ts/ts_req_utils.c +234 -0
  719. data/lib/extensions/openssl.so/ext/sources/crypto/ts/ts_rsp_print.c +287 -0
  720. data/lib/extensions/openssl.so/ext/sources/crypto/ts/ts_rsp_sign.c +1020 -0
  721. data/lib/extensions/openssl.so/ext/sources/crypto/ts/ts_rsp_utils.c +409 -0
  722. data/lib/extensions/openssl.so/ext/sources/crypto/ts/ts_rsp_verify.c +728 -0
  723. data/lib/extensions/openssl.so/ext/sources/crypto/ts/ts_verify_ctx.c +159 -0
  724. data/lib/extensions/openssl.so/ext/sources/crypto/txt_db/txt_db.c +388 -0
  725. data/lib/extensions/openssl.so/ext/sources/crypto/txt_db/txt_db.h +112 -0
  726. data/lib/extensions/openssl.so/ext/sources/crypto/ui/ui.h +383 -0
  727. data/lib/extensions/openssl.so/ext/sources/crypto/ui/ui_compat.c +67 -0
  728. data/lib/extensions/openssl.so/ext/sources/crypto/ui/ui_compat.h +83 -0
  729. data/lib/extensions/openssl.so/ext/sources/crypto/ui/ui_err.c +112 -0
  730. data/lib/extensions/openssl.so/ext/sources/crypto/ui/ui_lib.c +924 -0
  731. data/lib/extensions/openssl.so/ext/sources/crypto/ui/ui_locl.h +153 -0
  732. data/lib/extensions/openssl.so/ext/sources/crypto/ui/ui_openssl.c +712 -0
  733. data/lib/extensions/openssl.so/ext/sources/crypto/ui/ui_util.c +91 -0
  734. data/lib/extensions/openssl.so/ext/sources/crypto/uid.c +89 -0
  735. data/lib/extensions/openssl.so/ext/sources/crypto/vms_rms.h +51 -0
  736. data/lib/extensions/openssl.so/ext/sources/crypto/whrlpool/whrlpool.h +41 -0
  737. data/lib/extensions/openssl.so/ext/sources/crypto/whrlpool/wp_block.c +655 -0
  738. data/lib/extensions/openssl.so/ext/sources/crypto/whrlpool/wp_dgst.c +265 -0
  739. data/lib/extensions/openssl.so/ext/sources/crypto/whrlpool/wp_locl.h +3 -0
  740. data/lib/extensions/openssl.so/ext/sources/crypto/x509/by_dir.c +482 -0
  741. data/lib/extensions/openssl.so/ext/sources/crypto/x509/by_file.c +300 -0
  742. data/lib/extensions/openssl.so/ext/sources/crypto/x509/x509.h +1297 -0
  743. data/lib/extensions/openssl.so/ext/sources/crypto/x509/x509_att.c +359 -0
  744. data/lib/extensions/openssl.so/ext/sources/crypto/x509/x509_cmp.c +344 -0
  745. data/lib/extensions/openssl.so/ext/sources/crypto/x509/x509_d2.c +107 -0
  746. data/lib/extensions/openssl.so/ext/sources/crypto/x509/x509_def.c +81 -0
  747. data/lib/extensions/openssl.so/ext/sources/crypto/x509/x509_err.c +164 -0
  748. data/lib/extensions/openssl.so/ext/sources/crypto/x509/x509_ext.c +210 -0
  749. data/lib/extensions/openssl.so/ext/sources/crypto/x509/x509_lu.c +716 -0
  750. data/lib/extensions/openssl.so/ext/sources/crypto/x509/x509_obj.c +226 -0
  751. data/lib/extensions/openssl.so/ext/sources/crypto/x509/x509_r2x.c +114 -0
  752. data/lib/extensions/openssl.so/ext/sources/crypto/x509/x509_req.c +316 -0
  753. data/lib/extensions/openssl.so/ext/sources/crypto/x509/x509_set.c +150 -0
  754. data/lib/extensions/openssl.so/ext/sources/crypto/x509/x509_trs.c +288 -0
  755. data/lib/extensions/openssl.so/ext/sources/crypto/x509/x509_txt.c +193 -0
  756. data/lib/extensions/openssl.so/ext/sources/crypto/x509/x509_v3.c +274 -0
  757. data/lib/extensions/openssl.so/ext/sources/crypto/x509/x509_vfy.c +2214 -0
  758. data/lib/extensions/openssl.so/ext/sources/crypto/x509/x509_vfy.h +567 -0
  759. data/lib/extensions/openssl.so/ext/sources/crypto/x509/x509_vpm.c +438 -0
  760. data/lib/extensions/openssl.so/ext/sources/crypto/x509/x509cset.c +170 -0
  761. data/lib/extensions/openssl.so/ext/sources/crypto/x509/x509name.c +383 -0
  762. data/lib/extensions/openssl.so/ext/sources/crypto/x509/x509rset.c +83 -0
  763. data/lib/extensions/openssl.so/ext/sources/crypto/x509/x509spki.c +121 -0
  764. data/lib/extensions/openssl.so/ext/sources/crypto/x509/x509type.c +131 -0
  765. data/lib/extensions/openssl.so/ext/sources/crypto/x509/x_all.c +535 -0
  766. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/ext_dat.h +132 -0
  767. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/pcy_cache.c +286 -0
  768. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/pcy_data.c +135 -0
  769. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/pcy_int.h +212 -0
  770. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/pcy_lib.c +167 -0
  771. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/pcy_map.c +132 -0
  772. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/pcy_node.c +197 -0
  773. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/pcy_tree.c +872 -0
  774. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_addr.c +1338 -0
  775. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_akey.c +208 -0
  776. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_akeya.c +72 -0
  777. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_alt.c +614 -0
  778. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_asid.c +890 -0
  779. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_bcons.c +124 -0
  780. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_bitst.c +141 -0
  781. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_conf.c +525 -0
  782. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_cpols.c +457 -0
  783. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_crld.c +616 -0
  784. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_enum.c +97 -0
  785. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_extku.c +144 -0
  786. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_genn.c +252 -0
  787. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_ia5.c +116 -0
  788. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_info.c +193 -0
  789. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_int.c +89 -0
  790. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_lib.c +309 -0
  791. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_ncons.c +505 -0
  792. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_ocsp.c +289 -0
  793. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_pci.c +328 -0
  794. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_pcia.c +55 -0
  795. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_pcons.c +140 -0
  796. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_pku.c +108 -0
  797. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_pmaps.c +155 -0
  798. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_prn.c +234 -0
  799. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_purp.c +767 -0
  800. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_skey.c +145 -0
  801. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_sxnet.c +262 -0
  802. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3_utl.c +874 -0
  803. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/v3err.c +226 -0
  804. data/lib/extensions/openssl.so/ext/sources/crypto/x509v3/x509v3.h +1007 -0
  805. data/lib/extensions/openssl.so/ext/sources/e_os.h +735 -0
  806. data/lib/extensions/openssl.so/ext/sources/e_os2.h +315 -0
  807. data/lib/extensions/openssl.so/ext/sources/engines/ccgost/e_gost_err.c +212 -0
  808. data/lib/extensions/openssl.so/ext/sources/engines/ccgost/e_gost_err.h +156 -0
  809. data/lib/extensions/openssl.so/ext/sources/engines/ccgost/gost2001.c +343 -0
  810. data/lib/extensions/openssl.so/ext/sources/engines/ccgost/gost2001_keyx.c +308 -0
  811. data/lib/extensions/openssl.so/ext/sources/engines/ccgost/gost2001_keyx.h +10 -0
  812. data/lib/extensions/openssl.so/ext/sources/engines/ccgost/gost89.c +409 -0
  813. data/lib/extensions/openssl.so/ext/sources/engines/ccgost/gost89.h +96 -0
  814. data/lib/extensions/openssl.so/ext/sources/engines/ccgost/gost94_keyx.c +291 -0
  815. data/lib/extensions/openssl.so/ext/sources/engines/ccgost/gost_ameth.c +945 -0
  816. data/lib/extensions/openssl.so/ext/sources/engines/ccgost/gost_asn1.c +55 -0
  817. data/lib/extensions/openssl.so/ext/sources/engines/ccgost/gost_crypt.c +617 -0
  818. data/lib/extensions/openssl.so/ext/sources/engines/ccgost/gost_ctl.c +89 -0
  819. data/lib/extensions/openssl.so/ext/sources/engines/ccgost/gost_eng.c +273 -0
  820. data/lib/extensions/openssl.so/ext/sources/engines/ccgost/gost_keywrap.c +109 -0
  821. data/lib/extensions/openssl.so/ext/sources/engines/ccgost/gost_keywrap.h +56 -0
  822. data/lib/extensions/openssl.so/ext/sources/engines/ccgost/gost_lcl.h +221 -0
  823. data/lib/extensions/openssl.so/ext/sources/engines/ccgost/gost_md.c +75 -0
  824. data/lib/extensions/openssl.so/ext/sources/engines/ccgost/gost_params.c +198 -0
  825. data/lib/extensions/openssl.so/ext/sources/engines/ccgost/gost_params.h +34 -0
  826. data/lib/extensions/openssl.so/ext/sources/engines/ccgost/gost_pmeth.c +628 -0
  827. data/lib/extensions/openssl.so/ext/sources/engines/ccgost/gost_sign.c +321 -0
  828. data/lib/extensions/openssl.so/ext/sources/engines/ccgost/gosthash.c +255 -0
  829. data/lib/extensions/openssl.so/ext/sources/engines/ccgost/gosthash.h +48 -0
  830. data/lib/extensions/openssl.so/ext/sources/engines/e_4758cca.c +987 -0
  831. data/lib/extensions/openssl.so/ext/sources/engines/e_4758cca_err.c +153 -0
  832. data/lib/extensions/openssl.so/ext/sources/engines/e_4758cca_err.h +97 -0
  833. data/lib/extensions/openssl.so/ext/sources/engines/e_aep.c +1139 -0
  834. data/lib/extensions/openssl.so/ext/sources/engines/e_aep_err.c +161 -0
  835. data/lib/extensions/openssl.so/ext/sources/engines/e_aep_err.h +105 -0
  836. data/lib/extensions/openssl.so/ext/sources/engines/e_atalla.c +607 -0
  837. data/lib/extensions/openssl.so/ext/sources/engines/e_atalla_err.c +149 -0
  838. data/lib/extensions/openssl.so/ext/sources/engines/e_atalla_err.h +93 -0
  839. data/lib/extensions/openssl.so/ext/sources/engines/e_capi.c +1913 -0
  840. data/lib/extensions/openssl.so/ext/sources/engines/e_capi_err.c +184 -0
  841. data/lib/extensions/openssl.so/ext/sources/engines/e_capi_err.h +128 -0
  842. data/lib/extensions/openssl.so/ext/sources/engines/e_chil.c +1356 -0
  843. data/lib/extensions/openssl.so/ext/sources/engines/e_chil_err.c +160 -0
  844. data/lib/extensions/openssl.so/ext/sources/engines/e_chil_err.h +104 -0
  845. data/lib/extensions/openssl.so/ext/sources/engines/e_cswift.c +1129 -0
  846. data/lib/extensions/openssl.so/ext/sources/engines/e_cswift_err.c +154 -0
  847. data/lib/extensions/openssl.so/ext/sources/engines/e_cswift_err.h +98 -0
  848. data/lib/extensions/openssl.so/ext/sources/engines/e_gmp.c +480 -0
  849. data/lib/extensions/openssl.so/ext/sources/engines/e_gmp_err.c +141 -0
  850. data/lib/extensions/openssl.so/ext/sources/engines/e_gmp_err.h +85 -0
  851. data/lib/extensions/openssl.so/ext/sources/engines/e_nuron.c +434 -0
  852. data/lib/extensions/openssl.so/ext/sources/engines/e_nuron_err.c +146 -0
  853. data/lib/extensions/openssl.so/ext/sources/engines/e_nuron_err.h +90 -0
  854. data/lib/extensions/openssl.so/ext/sources/engines/e_padlock.c +1239 -0
  855. data/lib/extensions/openssl.so/ext/sources/engines/e_sureware.c +1055 -0
  856. data/lib/extensions/openssl.so/ext/sources/engines/e_sureware_err.c +158 -0
  857. data/lib/extensions/openssl.so/ext/sources/engines/e_sureware_err.h +102 -0
  858. data/lib/extensions/openssl.so/ext/sources/engines/e_ubsec.c +1069 -0
  859. data/lib/extensions/openssl.so/ext/sources/engines/e_ubsec_err.c +157 -0
  860. data/lib/extensions/openssl.so/ext/sources/engines/e_ubsec_err.h +101 -0
  861. data/lib/extensions/openssl.so/ext/sources/engines/vendor_defns/aep.h +178 -0
  862. data/lib/extensions/openssl.so/ext/sources/engines/vendor_defns/atalla.h +48 -0
  863. data/lib/extensions/openssl.so/ext/sources/engines/vendor_defns/cswift.h +234 -0
  864. data/lib/extensions/openssl.so/ext/sources/engines/vendor_defns/hw_4758_cca.h +149 -0
  865. data/lib/extensions/openssl.so/ext/sources/engines/vendor_defns/hw_ubsec.h +100 -0
  866. data/lib/extensions/openssl.so/ext/sources/engines/vendor_defns/hwcryptohook.h +486 -0
  867. data/lib/extensions/openssl.so/ext/sources/engines/vendor_defns/sureware.h +239 -0
  868. data/lib/extensions/openssl.so/ext/sources/include/openssl/aes.h +1 -0
  869. data/lib/extensions/openssl.so/ext/sources/include/openssl/asn1.h +1 -0
  870. data/lib/extensions/openssl.so/ext/sources/include/openssl/asn1_mac.h +1 -0
  871. data/lib/extensions/openssl.so/ext/sources/include/openssl/asn1t.h +1 -0
  872. data/lib/extensions/openssl.so/ext/sources/include/openssl/bio.h +1 -0
  873. data/lib/extensions/openssl.so/ext/sources/include/openssl/blowfish.h +1 -0
  874. data/lib/extensions/openssl.so/ext/sources/include/openssl/bn.h +1 -0
  875. data/lib/extensions/openssl.so/ext/sources/include/openssl/buffer.h +1 -0
  876. data/lib/extensions/openssl.so/ext/sources/include/openssl/camellia.h +1 -0
  877. data/lib/extensions/openssl.so/ext/sources/include/openssl/cast.h +1 -0
  878. data/lib/extensions/openssl.so/ext/sources/include/openssl/cmac.h +1 -0
  879. data/lib/extensions/openssl.so/ext/sources/include/openssl/cms.h +1 -0
  880. data/lib/extensions/openssl.so/ext/sources/include/openssl/comp.h +1 -0
  881. data/lib/extensions/openssl.so/ext/sources/include/openssl/conf.h +1 -0
  882. data/lib/extensions/openssl.so/ext/sources/include/openssl/conf_api.h +1 -0
  883. data/lib/extensions/openssl.so/ext/sources/include/openssl/crypto.h +1 -0
  884. data/lib/extensions/openssl.so/ext/sources/include/openssl/des.h +1 -0
  885. data/lib/extensions/openssl.so/ext/sources/include/openssl/des_old.h +1 -0
  886. data/lib/extensions/openssl.so/ext/sources/include/openssl/dh.h +1 -0
  887. data/lib/extensions/openssl.so/ext/sources/include/openssl/dsa.h +1 -0
  888. data/lib/extensions/openssl.so/ext/sources/include/openssl/dso.h +1 -0
  889. data/lib/extensions/openssl.so/ext/sources/include/openssl/dtls1.h +1 -0
  890. data/lib/extensions/openssl.so/ext/sources/include/openssl/e_os2.h +1 -0
  891. data/lib/extensions/openssl.so/ext/sources/include/openssl/ebcdic.h +1 -0
  892. data/lib/extensions/openssl.so/ext/sources/include/openssl/ec.h +1 -0
  893. data/lib/extensions/openssl.so/ext/sources/include/openssl/ecdh.h +1 -0
  894. data/lib/extensions/openssl.so/ext/sources/include/openssl/ecdsa.h +1 -0
  895. data/lib/extensions/openssl.so/ext/sources/include/openssl/engine.h +1 -0
  896. data/lib/extensions/openssl.so/ext/sources/include/openssl/err.h +1 -0
  897. data/lib/extensions/openssl.so/ext/sources/include/openssl/evp.h +1 -0
  898. data/lib/extensions/openssl.so/ext/sources/include/openssl/hmac.h +1 -0
  899. data/lib/extensions/openssl.so/ext/sources/include/openssl/idea.h +1 -0
  900. data/lib/extensions/openssl.so/ext/sources/include/openssl/krb5_asn.h +1 -0
  901. data/lib/extensions/openssl.so/ext/sources/include/openssl/kssl.h +1 -0
  902. data/lib/extensions/openssl.so/ext/sources/include/openssl/lhash.h +1 -0
  903. data/lib/extensions/openssl.so/ext/sources/include/openssl/md4.h +1 -0
  904. data/lib/extensions/openssl.so/ext/sources/include/openssl/md5.h +1 -0
  905. data/lib/extensions/openssl.so/ext/sources/include/openssl/mdc2.h +1 -0
  906. data/lib/extensions/openssl.so/ext/sources/include/openssl/modes.h +1 -0
  907. data/lib/extensions/openssl.so/ext/sources/include/openssl/obj_mac.h +1 -0
  908. data/lib/extensions/openssl.so/ext/sources/include/openssl/objects.h +1 -0
  909. data/lib/extensions/openssl.so/ext/sources/include/openssl/ocsp.h +1 -0
  910. data/lib/extensions/openssl.so/ext/sources/include/openssl/opensslconf.h +1 -0
  911. data/lib/extensions/openssl.so/ext/sources/include/openssl/opensslv.h +1 -0
  912. data/lib/extensions/openssl.so/ext/sources/include/openssl/ossl_typ.h +1 -0
  913. data/lib/extensions/openssl.so/ext/sources/include/openssl/pem.h +1 -0
  914. data/lib/extensions/openssl.so/ext/sources/include/openssl/pem2.h +1 -0
  915. data/lib/extensions/openssl.so/ext/sources/include/openssl/pkcs12.h +1 -0
  916. data/lib/extensions/openssl.so/ext/sources/include/openssl/pkcs7.h +1 -0
  917. data/lib/extensions/openssl.so/ext/sources/include/openssl/pqueue.h +1 -0
  918. data/lib/extensions/openssl.so/ext/sources/include/openssl/rand.h +1 -0
  919. data/lib/extensions/openssl.so/ext/sources/include/openssl/rc2.h +1 -0
  920. data/lib/extensions/openssl.so/ext/sources/include/openssl/rc4.h +1 -0
  921. data/lib/extensions/openssl.so/ext/sources/include/openssl/ripemd.h +1 -0
  922. data/lib/extensions/openssl.so/ext/sources/include/openssl/rsa.h +1 -0
  923. data/lib/extensions/openssl.so/ext/sources/include/openssl/safestack.h +1 -0
  924. data/lib/extensions/openssl.so/ext/sources/include/openssl/seed.h +1 -0
  925. data/lib/extensions/openssl.so/ext/sources/include/openssl/sha.h +1 -0
  926. data/lib/extensions/openssl.so/ext/sources/include/openssl/srp.h +1 -0
  927. data/lib/extensions/openssl.so/ext/sources/include/openssl/srtp.h +1 -0
  928. data/lib/extensions/openssl.so/ext/sources/include/openssl/ssl.h +1 -0
  929. data/lib/extensions/openssl.so/ext/sources/include/openssl/ssl2.h +1 -0
  930. data/lib/extensions/openssl.so/ext/sources/include/openssl/ssl23.h +1 -0
  931. data/lib/extensions/openssl.so/ext/sources/include/openssl/ssl3.h +1 -0
  932. data/lib/extensions/openssl.so/ext/sources/include/openssl/stack.h +1 -0
  933. data/lib/extensions/openssl.so/ext/sources/include/openssl/store.h +1 -0
  934. data/lib/extensions/openssl.so/ext/sources/include/openssl/symhacks.h +1 -0
  935. data/lib/extensions/openssl.so/ext/sources/include/openssl/tls1.h +1 -0
  936. data/lib/extensions/openssl.so/ext/sources/include/openssl/ts.h +1 -0
  937. data/lib/extensions/openssl.so/ext/sources/include/openssl/txt_db.h +1 -0
  938. data/lib/extensions/openssl.so/ext/sources/include/openssl/ui.h +1 -0
  939. data/lib/extensions/openssl.so/ext/sources/include/openssl/ui_compat.h +1 -0
  940. data/lib/extensions/openssl.so/ext/sources/include/openssl/whrlpool.h +1 -0
  941. data/lib/extensions/openssl.so/ext/sources/include/openssl/x509.h +1 -0
  942. data/lib/extensions/openssl.so/ext/sources/include/openssl/x509_vfy.h +1 -0
  943. data/lib/extensions/openssl.so/ext/sources/include/openssl/x509v3.h +1 -0
  944. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/assert.h +50 -0
  945. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/conio.h +40 -0
  946. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/ctype.h +90 -0
  947. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/direct.h +22 -0
  948. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/errno.h +158 -0
  949. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/fcntl.h +56 -0
  950. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/float.h +330 -0
  951. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/io.h +63 -0
  952. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/limits.h +95 -0
  953. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/malloc.h +59 -0
  954. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/math.h +95 -0
  955. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/memory.h +44 -0
  956. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/process.h +59 -0
  957. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/setjmp.h +69 -0
  958. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/signal.h +53 -0
  959. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/stdarg.h +78 -0
  960. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/stddef.h +88 -0
  961. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/stdio.h +182 -0
  962. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/stdlib.h +142 -0
  963. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/string.h +109 -0
  964. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/strings.h +3 -0
  965. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/sys/locking.h +31 -0
  966. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/sys/stat.h +92 -0
  967. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/sys/time.h +20 -0
  968. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/sys/timeb.h +58 -0
  969. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/sys/types.h +35 -0
  970. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/sys/utime.h +21 -0
  971. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/time.h +81 -0
  972. data/lib/extensions/openssl.so/ext/sources/include/wcecompat/winsock_extras.h +46 -0
  973. data/lib/extensions/openssl.so/ext/sources/ssl/bio_ssl.c +605 -0
  974. data/lib/extensions/openssl.so/ext/sources/ssl/d1_both.c +1591 -0
  975. data/lib/extensions/openssl.so/ext/sources/ssl/d1_clnt.c +1710 -0
  976. data/lib/extensions/openssl.so/ext/sources/ssl/d1_enc.c +289 -0
  977. data/lib/extensions/openssl.so/ext/sources/ssl/d1_lib.c +482 -0
  978. data/lib/extensions/openssl.so/ext/sources/ssl/d1_meth.c +77 -0
  979. data/lib/extensions/openssl.so/ext/sources/ssl/d1_pkt.c +1876 -0
  980. data/lib/extensions/openssl.so/ext/sources/ssl/d1_srtp.c +493 -0
  981. data/lib/extensions/openssl.so/ext/sources/ssl/d1_srvr.c +1711 -0
  982. data/lib/extensions/openssl.so/ext/sources/ssl/dtls1.h +283 -0
  983. data/lib/extensions/openssl.so/ext/sources/ssl/kssl.c +2221 -0
  984. data/lib/extensions/openssl.so/ext/sources/ssl/kssl.h +183 -0
  985. data/lib/extensions/openssl.so/ext/sources/ssl/kssl_lcl.h +87 -0
  986. data/lib/extensions/openssl.so/ext/sources/ssl/s23_clnt.c +779 -0
  987. data/lib/extensions/openssl.so/ext/sources/ssl/s23_lib.c +187 -0
  988. data/lib/extensions/openssl.so/ext/sources/ssl/s23_meth.c +92 -0
  989. data/lib/extensions/openssl.so/ext/sources/ssl/s23_pkt.c +117 -0
  990. data/lib/extensions/openssl.so/ext/sources/ssl/s23_srvr.c +638 -0
  991. data/lib/extensions/openssl.so/ext/sources/ssl/s2_clnt.c +1125 -0
  992. data/lib/extensions/openssl.so/ext/sources/ssl/s2_enc.c +193 -0
  993. data/lib/extensions/openssl.so/ext/sources/ssl/s2_lib.c +556 -0
  994. data/lib/extensions/openssl.so/ext/sources/ssl/s2_meth.c +84 -0
  995. data/lib/extensions/openssl.so/ext/sources/ssl/s2_pkt.c +744 -0
  996. data/lib/extensions/openssl.so/ext/sources/ssl/s2_srvr.c +1142 -0
  997. data/lib/extensions/openssl.so/ext/sources/ssl/s3_both.c +843 -0
  998. data/lib/extensions/openssl.so/ext/sources/ssl/s3_clnt.c +3371 -0
  999. data/lib/extensions/openssl.so/ext/sources/ssl/s3_enc.c +861 -0
  1000. data/lib/extensions/openssl.so/ext/sources/ssl/s3_lib.c +4282 -0
  1001. data/lib/extensions/openssl.so/ext/sources/ssl/s3_meth.c +77 -0
  1002. data/lib/extensions/openssl.so/ext/sources/ssl/s3_pkt.c +1518 -0
  1003. data/lib/extensions/openssl.so/ext/sources/ssl/s3_srvr.c +3586 -0
  1004. data/lib/extensions/openssl.so/ext/sources/ssl/srtp.h +145 -0
  1005. data/lib/extensions/openssl.so/ext/sources/ssl/ssl.h +2573 -0
  1006. data/lib/extensions/openssl.so/ext/sources/ssl/ssl2.h +272 -0
  1007. data/lib/extensions/openssl.so/ext/sources/ssl/ssl23.h +83 -0
  1008. data/lib/extensions/openssl.so/ext/sources/ssl/ssl3.h +678 -0
  1009. data/lib/extensions/openssl.so/ext/sources/ssl/ssl_algs.c +149 -0
  1010. data/lib/extensions/openssl.so/ext/sources/ssl/ssl_asn1.c +642 -0
  1011. data/lib/extensions/openssl.so/ext/sources/ssl/ssl_cert.c +853 -0
  1012. data/lib/extensions/openssl.so/ext/sources/ssl/ssl_ciph.c +1852 -0
  1013. data/lib/extensions/openssl.so/ext/sources/ssl/ssl_err.c +609 -0
  1014. data/lib/extensions/openssl.so/ext/sources/ssl/ssl_err2.c +70 -0
  1015. data/lib/extensions/openssl.so/ext/sources/ssl/ssl_lib.c +3251 -0
  1016. data/lib/extensions/openssl.so/ext/sources/ssl/ssl_locl.h +1134 -0
  1017. data/lib/extensions/openssl.so/ext/sources/ssl/ssl_rsa.c +779 -0
  1018. data/lib/extensions/openssl.so/ext/sources/ssl/ssl_sess.c +1159 -0
  1019. data/lib/extensions/openssl.so/ext/sources/ssl/ssl_stat.c +567 -0
  1020. data/lib/extensions/openssl.so/ext/sources/ssl/ssl_txt.c +248 -0
  1021. data/lib/extensions/openssl.so/ext/sources/ssl/t1_clnt.c +92 -0
  1022. data/lib/extensions/openssl.so/ext/sources/ssl/t1_enc.c +1256 -0
  1023. data/lib/extensions/openssl.so/ext/sources/ssl/t1_lib.c +2578 -0
  1024. data/lib/extensions/openssl.so/ext/sources/ssl/t1_meth.c +88 -0
  1025. data/lib/extensions/openssl.so/ext/sources/ssl/t1_reneg.c +292 -0
  1026. data/lib/extensions/openssl.so/ext/sources/ssl/t1_srvr.c +93 -0
  1027. data/lib/extensions/openssl.so/ext/sources/ssl/tls1.h +735 -0
  1028. data/lib/extensions/openssl.so/ext/sources/ssl/tls_srp.c +506 -0
  1029. data/lib/extensions/openssl.so/ext/win32/UPDATE +15 -0
  1030. data/lib/extensions/openssl.so/ext/win32/bin/libeay32.dll +0 -0
  1031. data/lib/extensions/openssl.so/ext/win32/bin/ssleay32.dll +0 -0
  1032. data/lib/extensions/openssl.so/ext/win32/include/openssl/aes.h +147 -0
  1033. data/lib/extensions/openssl.so/ext/win32/include/openssl/applink.c +94 -0
  1034. data/lib/extensions/openssl.so/ext/win32/include/openssl/asn1.h +1404 -0
  1035. data/lib/extensions/openssl.so/ext/win32/include/openssl/asn1_mac.h +578 -0
  1036. data/lib/extensions/openssl.so/ext/win32/include/openssl/asn1t.h +960 -0
  1037. data/lib/extensions/openssl.so/ext/win32/include/openssl/bio.h +847 -0
  1038. data/lib/extensions/openssl.so/ext/win32/include/openssl/blowfish.h +129 -0
  1039. data/lib/extensions/openssl.so/ext/win32/include/openssl/bn.h +891 -0
  1040. data/lib/extensions/openssl.so/ext/win32/include/openssl/buffer.h +119 -0
  1041. data/lib/extensions/openssl.so/ext/win32/include/openssl/camellia.h +130 -0
  1042. data/lib/extensions/openssl.so/ext/win32/include/openssl/cast.h +107 -0
  1043. data/lib/extensions/openssl.so/ext/win32/include/openssl/cmac.h +82 -0
  1044. data/lib/extensions/openssl.so/ext/win32/include/openssl/cms.h +501 -0
  1045. data/lib/extensions/openssl.so/ext/win32/include/openssl/comp.h +80 -0
  1046. data/lib/extensions/openssl.so/ext/win32/include/openssl/conf.h +263 -0
  1047. data/lib/extensions/openssl.so/ext/win32/include/openssl/conf_api.h +89 -0
  1048. data/lib/extensions/openssl.so/ext/win32/include/openssl/crypto.h +604 -0
  1049. data/lib/extensions/openssl.so/ext/win32/include/openssl/des.h +248 -0
  1050. data/lib/extensions/openssl.so/ext/win32/include/openssl/des_old.h +446 -0
  1051. data/lib/extensions/openssl.so/ext/win32/include/openssl/dh.h +280 -0
  1052. data/lib/extensions/openssl.so/ext/win32/include/openssl/dsa.h +327 -0
  1053. data/lib/extensions/openssl.so/ext/win32/include/openssl/dso.h +409 -0
  1054. data/lib/extensions/openssl.so/ext/win32/include/openssl/dtls1.h +283 -0
  1055. data/lib/extensions/openssl.so/ext/win32/include/openssl/e_os2.h +315 -0
  1056. data/lib/extensions/openssl.so/ext/win32/include/openssl/ebcdic.h +19 -0
  1057. data/lib/extensions/openssl.so/ext/win32/include/openssl/ec.h +1159 -0
  1058. data/lib/extensions/openssl.so/ext/win32/include/openssl/ecdh.h +125 -0
  1059. data/lib/extensions/openssl.so/ext/win32/include/openssl/ecdsa.h +260 -0
  1060. data/lib/extensions/openssl.so/ext/win32/include/openssl/engine.h +842 -0
  1061. data/lib/extensions/openssl.so/ext/win32/include/openssl/err.h +386 -0
  1062. data/lib/extensions/openssl.so/ext/win32/include/openssl/evp.h +1402 -0
  1063. data/lib/extensions/openssl.so/ext/win32/include/openssl/hmac.h +110 -0
  1064. data/lib/extensions/openssl.so/ext/win32/include/openssl/idea.h +103 -0
  1065. data/lib/extensions/openssl.so/ext/win32/include/openssl/krb5_asn.h +256 -0
  1066. data/lib/extensions/openssl.so/ext/win32/include/openssl/kssl.h +183 -0
  1067. data/lib/extensions/openssl.so/ext/win32/include/openssl/lhash.h +241 -0
  1068. data/lib/extensions/openssl.so/ext/win32/include/openssl/md4.h +120 -0
  1069. data/lib/extensions/openssl.so/ext/win32/include/openssl/md5.h +120 -0
  1070. data/lib/extensions/openssl.so/ext/win32/include/openssl/mdc2.h +98 -0
  1071. data/lib/extensions/openssl.so/ext/win32/include/openssl/modes.h +135 -0
  1072. data/lib/extensions/openssl.so/ext/win32/include/openssl/obj_mac.h +4032 -0
  1073. data/lib/extensions/openssl.so/ext/win32/include/openssl/objects.h +1138 -0
  1074. data/lib/extensions/openssl.so/ext/win32/include/openssl/ocsp.h +623 -0
  1075. data/lib/extensions/openssl.so/ext/win32/include/openssl/opensslconf.h +235 -0
  1076. data/lib/extensions/openssl.so/ext/win32/include/openssl/opensslv.h +89 -0
  1077. data/lib/extensions/openssl.so/ext/win32/include/openssl/ossl_typ.h +202 -0
  1078. data/lib/extensions/openssl.so/ext/win32/include/openssl/pem.h +641 -0
  1079. data/lib/extensions/openssl.so/ext/win32/include/openssl/pem2.h +70 -0
  1080. data/lib/extensions/openssl.so/ext/win32/include/openssl/pkcs12.h +331 -0
  1081. data/lib/extensions/openssl.so/ext/win32/include/openssl/pkcs7.h +499 -0
  1082. data/lib/extensions/openssl.so/ext/win32/include/openssl/pqueue.h +94 -0
  1083. data/lib/extensions/openssl.so/ext/win32/include/openssl/rand.h +149 -0
  1084. data/lib/extensions/openssl.so/ext/win32/include/openssl/rc2.h +103 -0
  1085. data/lib/extensions/openssl.so/ext/win32/include/openssl/rc4.h +90 -0
  1086. data/lib/extensions/openssl.so/ext/win32/include/openssl/ripemd.h +107 -0
  1087. data/lib/extensions/openssl.so/ext/win32/include/openssl/rsa.h +582 -0
  1088. data/lib/extensions/openssl.so/ext/win32/include/openssl/safestack.h +2663 -0
  1089. data/lib/extensions/openssl.so/ext/win32/include/openssl/seed.h +139 -0
  1090. data/lib/extensions/openssl.so/ext/win32/include/openssl/sha.h +214 -0
  1091. data/lib/extensions/openssl.so/ext/win32/include/openssl/srp.h +172 -0
  1092. data/lib/extensions/openssl.so/ext/win32/include/openssl/srtp.h +145 -0
  1093. data/lib/extensions/openssl.so/ext/win32/include/openssl/ssl.h +2572 -0
  1094. data/lib/extensions/openssl.so/ext/win32/include/openssl/ssl2.h +272 -0
  1095. data/lib/extensions/openssl.so/ext/win32/include/openssl/ssl23.h +83 -0
  1096. data/lib/extensions/openssl.so/ext/win32/include/openssl/ssl3.h +678 -0
  1097. data/lib/extensions/openssl.so/ext/win32/include/openssl/stack.h +108 -0
  1098. data/lib/extensions/openssl.so/ext/win32/include/openssl/symhacks.h +477 -0
  1099. data/lib/extensions/openssl.so/ext/win32/include/openssl/tls1.h +735 -0
  1100. data/lib/extensions/openssl.so/ext/win32/include/openssl/ts.h +858 -0
  1101. data/lib/extensions/openssl.so/ext/win32/include/openssl/txt_db.h +112 -0
  1102. data/lib/extensions/openssl.so/ext/win32/include/openssl/ui.h +383 -0
  1103. data/lib/extensions/openssl.so/ext/win32/include/openssl/ui_compat.h +83 -0
  1104. data/lib/extensions/openssl.so/ext/win32/include/openssl/whrlpool.h +41 -0
  1105. data/lib/extensions/openssl.so/ext/win32/include/openssl/x509.h +1297 -0
  1106. data/lib/extensions/openssl.so/ext/win32/include/openssl/x509_vfy.h +567 -0
  1107. data/lib/extensions/openssl.so/ext/win32/include/openssl/x509v3.h +1007 -0
  1108. data/lib/extensions/openssl.so/ext/win32/lib/libeay32.lib +0 -0
  1109. data/lib/extensions/openssl.so/ext/win32/lib/ssleay32.lib +0 -0
  1110. data/lib/extensions/openssl.so/ext/wm/lib/libopenssl.lib +0 -0
  1111. data/lib/extensions/openssl.so/ext/wm/openssl.sln +30 -0
  1112. data/lib/extensions/openssl.so/ext/wm/openssl.vcproj +3254 -0
  1113. data/lib/extensions/openssl.so/ext/wm/tmp/MC3000c50b (ARMV4I)/Release/BuildLog.htm +0 -0
  1114. data/lib/extensions/openssl.so/ext/wm/tmp/Windows Mobile 6 Professional SDK (ARMV4I)/Release/BuildLog.htm +0 -0
  1115. data/lib/extensions/openssl.so/openssl.so.rb +1 -0
  1116. data/lib/extensions/openssl/ext.yml +2 -0
  1117. data/lib/extensions/openssl/ext/Rakefile +132 -0
  1118. data/lib/extensions/openssl/ext/android/extconf.h +55 -0
  1119. data/lib/extensions/openssl/ext/build +12 -0
  1120. data/lib/extensions/openssl/ext/build.bat +1 -0
  1121. data/lib/extensions/openssl/ext/extconf.rb +141 -0
  1122. data/lib/extensions/openssl/ext/iphone/Rakefile +79 -0
  1123. data/lib/extensions/openssl/ext/iphone/extconf.h +55 -0
  1124. data/lib/extensions/openssl/ext/iphone/openssl.xcodeproj/project.pbxproj +472 -0
  1125. data/lib/extensions/openssl/ext/iphone/openssl_Prefix.pch +7 -0
  1126. data/lib/extensions/openssl/ext/macosx/extconf.h +53 -0
  1127. data/lib/extensions/openssl/ext/openssl.sln +44 -0
  1128. data/lib/extensions/openssl/ext/openssl.vcproj +844 -0
  1129. data/lib/extensions/openssl/ext/openssl_missing.c +361 -0
  1130. data/lib/extensions/openssl/ext/openssl_missing.h +194 -0
  1131. data/lib/extensions/openssl/ext/ossl.c +514 -0
  1132. data/lib/extensions/openssl/ext/ossl.h +243 -0
  1133. data/lib/extensions/openssl/ext/ossl_asn1.c +1170 -0
  1134. data/lib/extensions/openssl/ext/ossl_asn1.h +59 -0
  1135. data/lib/extensions/openssl/ext/ossl_bio.c +86 -0
  1136. data/lib/extensions/openssl/ext/ossl_bio.h +21 -0
  1137. data/lib/extensions/openssl/ext/ossl_bn.c +852 -0
  1138. data/lib/extensions/openssl/ext/ossl_bn.h +25 -0
  1139. data/lib/extensions/openssl/ext/ossl_cipher.c +546 -0
  1140. data/lib/extensions/openssl/ext/ossl_cipher.h +22 -0
  1141. data/lib/extensions/openssl/ext/ossl_config.c +492 -0
  1142. data/lib/extensions/openssl/ext/ossl_config.h +22 -0
  1143. data/lib/extensions/openssl/ext/ossl_digest.c +257 -0
  1144. data/lib/extensions/openssl/ext/ossl_digest.h +22 -0
  1145. data/lib/extensions/openssl/ext/ossl_engine.c +411 -0
  1146. data/lib/extensions/openssl/ext/ossl_engine.h +20 -0
  1147. data/lib/extensions/openssl/ext/ossl_hmac.c +270 -0
  1148. data/lib/extensions/openssl/ext/ossl_hmac.h +19 -0
  1149. data/lib/extensions/openssl/ext/ossl_ns_spki.c +257 -0
  1150. data/lib/extensions/openssl/ext/ossl_ns_spki.h +21 -0
  1151. data/lib/extensions/openssl/ext/ossl_ocsp.c +773 -0
  1152. data/lib/extensions/openssl/ext/ossl_ocsp.h +24 -0
  1153. data/lib/extensions/openssl/ext/ossl_pkcs12.c +212 -0
  1154. data/lib/extensions/openssl/ext/ossl_pkcs12.h +15 -0
  1155. data/lib/extensions/openssl/ext/ossl_pkcs5.c +98 -0
  1156. data/lib/extensions/openssl/ext/ossl_pkcs5.h +6 -0
  1157. data/lib/extensions/openssl/ext/ossl_pkcs7.c +1041 -0
  1158. data/lib/extensions/openssl/ext/ossl_pkcs7.h +22 -0
  1159. data/lib/extensions/openssl/ext/ossl_pkey.c +240 -0
  1160. data/lib/extensions/openssl/ext/ossl_pkey.h +141 -0
  1161. data/lib/extensions/openssl/ext/ossl_pkey_dh.c +536 -0
  1162. data/lib/extensions/openssl/ext/ossl_pkey_dsa.c +492 -0
  1163. data/lib/extensions/openssl/ext/ossl_pkey_ec.c +1597 -0
  1164. data/lib/extensions/openssl/ext/ossl_pkey_rsa.c +601 -0
  1165. data/lib/extensions/openssl/ext/ossl_rand.c +202 -0
  1166. data/lib/extensions/openssl/ext/ossl_rand.h +20 -0
  1167. data/lib/extensions/openssl/ext/ossl_ssl.c +1691 -0
  1168. data/lib/extensions/openssl/ext/ossl_ssl.h +36 -0
  1169. data/lib/extensions/openssl/ext/ossl_ssl_session.c +306 -0
  1170. data/lib/extensions/openssl/ext/ossl_version.h +16 -0
  1171. data/lib/extensions/openssl/ext/ossl_x509.c +104 -0
  1172. data/lib/extensions/openssl/ext/ossl_x509.h +114 -0
  1173. data/lib/extensions/openssl/ext/ossl_x509attr.c +275 -0
  1174. data/lib/extensions/openssl/ext/ossl_x509cert.c +766 -0
  1175. data/lib/extensions/openssl/ext/ossl_x509crl.c +537 -0
  1176. data/lib/extensions/openssl/ext/ossl_x509ext.c +459 -0
  1177. data/lib/extensions/openssl/ext/ossl_x509name.c +375 -0
  1178. data/lib/extensions/openssl/ext/ossl_x509req.c +468 -0
  1179. data/lib/extensions/openssl/ext/ossl_x509revoked.c +229 -0
  1180. data/lib/extensions/openssl/ext/ossl_x509store.c +624 -0
  1181. data/lib/extensions/openssl/ext/ruby_missing.h +41 -0
  1182. data/lib/extensions/openssl/ext/windows/extconf.h +66 -0
  1183. data/lib/extensions/openssl/openssl.rb +24 -0
  1184. data/lib/extensions/openssl/openssl/bn.rb +35 -0
  1185. data/lib/extensions/openssl/openssl/buffering.rb +341 -0
  1186. data/lib/extensions/openssl/openssl/cipher.rb +65 -0
  1187. data/lib/extensions/openssl/openssl/digest.rb +61 -0
  1188. data/lib/extensions/openssl/openssl/ssl-internal.rb +178 -0
  1189. data/lib/extensions/openssl/openssl/ssl.rb +1 -0
  1190. data/lib/extensions/openssl/openssl/x509-internal.rb +153 -0
  1191. data/lib/extensions/openssl/openssl/x509.rb +1 -0
  1192. data/lib/extensions/rhoxml/rexml/xmldecl.rb +119 -0
  1193. data/lib/extensions/zlib/ext.yml +2 -0
  1194. data/lib/extensions/zlib/ext/README +115 -0
  1195. data/lib/extensions/zlib/ext/Rakefile +127 -0
  1196. data/lib/extensions/zlib/ext/adler32.c +179 -0
  1197. data/lib/extensions/zlib/ext/build +12 -0
  1198. data/lib/extensions/zlib/ext/build.bat +1 -0
  1199. data/lib/extensions/zlib/ext/compress.c +80 -0
  1200. data/lib/extensions/zlib/ext/crc32.c +425 -0
  1201. data/lib/extensions/zlib/ext/crc32.h +441 -0
  1202. data/lib/extensions/zlib/ext/deflate.c +1965 -0
  1203. data/lib/extensions/zlib/ext/deflate.h +346 -0
  1204. data/lib/extensions/zlib/ext/gzclose.c +25 -0
  1205. data/lib/extensions/zlib/ext/gzguts.h +193 -0
  1206. data/lib/extensions/zlib/ext/gzlib.c +620 -0
  1207. data/lib/extensions/zlib/ext/gzread.c +589 -0
  1208. data/lib/extensions/zlib/ext/gzwrite.c +565 -0
  1209. data/lib/extensions/zlib/ext/infback.c +640 -0
  1210. data/lib/extensions/zlib/ext/inffast.c +340 -0
  1211. data/lib/extensions/zlib/ext/inffast.h +11 -0
  1212. data/lib/extensions/zlib/ext/inffixed.h +94 -0
  1213. data/lib/extensions/zlib/ext/inflate.c +1496 -0
  1214. data/lib/extensions/zlib/ext/inflate.h +122 -0
  1215. data/lib/extensions/zlib/ext/inftrees.c +306 -0
  1216. data/lib/extensions/zlib/ext/inftrees.h +62 -0
  1217. data/lib/extensions/zlib/ext/iphone/Rakefile +79 -0
  1218. data/lib/extensions/zlib/ext/iphone/zlib.xcodeproj/project.pbxproj +360 -0
  1219. data/lib/extensions/zlib/ext/iphone/zlib_Prefix.pch +7 -0
  1220. data/lib/extensions/zlib/ext/trees.c +1224 -0
  1221. data/lib/extensions/zlib/ext/trees.h +128 -0
  1222. data/lib/extensions/zlib/ext/uncompr.c +59 -0
  1223. data/lib/extensions/zlib/ext/zconf.h +506 -0
  1224. data/lib/extensions/zlib/ext/zlib.c +3762 -0
  1225. data/lib/extensions/zlib/ext/zlib.h +1744 -0
  1226. data/lib/extensions/zlib/ext/zlib.sln +36 -0
  1227. data/lib/extensions/zlib/ext/zlib.vcproj +746 -0
  1228. data/lib/extensions/zlib/ext/zlib.vsprops +16 -0
  1229. data/lib/extensions/zlib/ext/zutil.c +324 -0
  1230. data/lib/extensions/zlib/ext/zutil.h +252 -0
  1231. data/lib/extensions/zlib/zlib.rb +0 -0
  1232. data/lib/framework/rbconfig.rb +1 -1
  1233. data/lib/framework/rho/render.rb +31 -34
  1234. data/lib/framework/rho/rho.rb +89 -24
  1235. data/lib/framework/rho/rhocontroller.rb +8 -5
  1236. data/lib/framework/rho/rhofsconnector.rb +3 -0
  1237. data/lib/framework/rhodes.rb +9 -9
  1238. data/lib/framework/rhom/rhom.rb +15 -0
  1239. data/lib/framework/rhom/rhom_db_adapter.rb +18 -0
  1240. data/lib/framework/rhom/rhom_object_factory.rb +36 -26
  1241. data/lib/framework/rhomotoapi.rb +65 -1
  1242. data/lib/framework/rhosystem.rb +23 -19
  1243. data/lib/framework/version.rb +7 -7
  1244. data/lib/rhodes.rb +9 -9
  1245. data/platform/android/Rhodes/AndroidManifest.xml +117 -117
  1246. data/platform/android/Rhodes/AndroidManifest.xml.erb +77 -0
  1247. data/platform/android/Rhodes/PushReceiver.erb +14 -0
  1248. data/platform/android/Rhodes/jni/Android.mk +3 -1
  1249. data/platform/android/Rhodes/jni/include/rhodes/jni/com_rhomobile_rhodes_Logger.h +16 -0
  1250. data/platform/android/Rhodes/jni/include/rhodes/jni/com_rhomobile_rhodes_RhodesService.h +8 -0
  1251. data/platform/android/Rhodes/jni/src/fileapi.cpp +18 -0
  1252. data/platform/android/Rhodes/jni/src/logger.cpp +16 -0
  1253. data/platform/android/Rhodes/jni/src/rhodesapp.cpp +9 -2
  1254. data/platform/android/Rhodes/jni/src/signature.cpp +3 -28
  1255. data/platform/android/Rhodes/src/com/rhomobile/rhodes/BaseActivity.java +41 -37
  1256. data/platform/android/Rhodes/src/com/rhomobile/rhodes/Logger.java +5 -5
  1257. data/platform/android/Rhodes/src/com/rhomobile/rhodes/PushReceiver.java +6 -2
  1258. data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesActivity.java +38 -15
  1259. data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesApplication.java +49 -9
  1260. data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesService.java +130 -10
  1261. data/platform/android/Rhodes/src/com/rhomobile/rhodes/bluetooth/RhoBluetoothManagerNew.java +13 -1
  1262. data/platform/android/Rhodes/src/com/rhomobile/rhodes/camera/Camera.java +8 -6
  1263. data/platform/android/Rhodes/src/com/rhomobile/rhodes/camera/CameraNewService.java +20 -0
  1264. data/platform/android/Rhodes/src/com/rhomobile/rhodes/camera/CameraOldService.java +5 -0
  1265. data/platform/android/Rhodes/src/com/rhomobile/rhodes/camera/CameraSemiService.java +14 -0
  1266. data/platform/android/Rhodes/src/com/rhomobile/rhodes/camera/CameraService.java +2 -0
  1267. data/platform/android/Rhodes/src/com/rhomobile/rhodes/camera/ImageCapture.java +16 -13
  1268. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/AbstractRhoExtension.java +1 -1
  1269. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/Config.java +3 -0
  1270. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/IRhoExtManager.java +1 -1
  1271. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/IRhoExtension.java +3 -1
  1272. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/RhoExtManager.java +10 -0
  1273. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/RhoExtManagerImpl.java +23 -35
  1274. data/platform/android/Rhodes/src/com/rhomobile/rhodes/file/RhoFileApi.java +10 -0
  1275. data/platform/android/Rhodes/src/com/rhomobile/rhodes/mainview/SplashScreen.java +60 -34
  1276. data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality.java +14 -1
  1277. data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality01.java +38 -3
  1278. data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality08.java +26 -4
  1279. data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality11.java +47 -0
  1280. data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionalityManager.java +4 -1
  1281. data/platform/android/Rhodes/src/com/rhomobile/rhodes/socket/RhoSocketImpl.java +9 -1
  1282. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/GoogleWebView.java +10 -0
  1283. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/IRhoWebView.java +2 -0
  1284. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/RhoWebViewClient.java +10 -3
  1285. data/platform/android/build/RhodesSRC_build.files +1 -1
  1286. data/platform/android/build/android.rake +567 -556
  1287. data/platform/android/build/android_tools.rb +87 -0
  1288. data/platform/android/build/librhocommon_build.files +3 -0
  1289. data/platform/android/build/librhodb_build.files +2 -0
  1290. data/platform/android/build/manifest_generator.rb +96 -0
  1291. data/platform/bb/Hsqldb/src/org/hsqldb/Expression.java +2 -4
  1292. data/platform/bb/RubyVM/src/com/rho/RhoProfiler.java +11 -0
  1293. data/platform/bb/RubyVM/src/com/xruby/runtime/lang/RhoSupport.java +61 -48
  1294. data/platform/bb/build/rhodes_build.files +0 -1
  1295. data/platform/bb/rhodes/platform/4.7/com/rho/rubyext/SignatureCapture.java +314 -0
  1296. data/platform/bb/rhodes/platform/common/com/rho/rubyext/SignatureCapture.java +312 -0
  1297. data/platform/bb/rhodes/src/rhomobile/RhodesApplication.java +4 -1
  1298. data/platform/iphone/Classes/AppManager/AppManager.h +1 -0
  1299. data/platform/iphone/Classes/AppManager/AppManager.m +165 -123
  1300. data/platform/iphone/Classes/Event/Event.m +53 -14
  1301. data/platform/iphone/Classes/Rhodes.h +5 -4
  1302. data/platform/iphone/Classes/Rhodes.m +10 -8
  1303. data/platform/iphone/Classes/Signature/SignatureDelegate.m +2 -2
  1304. data/platform/iphone/Classes/SimpleMainView.m +55 -17
  1305. data/platform/iphone/Classes/SplashViewController.m +28 -1
  1306. data/platform/iphone/Info.plist +59 -54
  1307. data/platform/iphone/RhoLib/RhoLib.xcodeproj/project.pbxproj +43 -14
  1308. data/platform/iphone/curl/curl.xcodeproj/project.pbxproj +15 -18
  1309. data/platform/iphone/rbuild/iphone.rake +113 -4
  1310. data/platform/iphone/rhoextlib/rhoextlib.xcodeproj/project.pbxproj +15 -17
  1311. data/platform/iphone/rhorubylib/rhorubylib.xcodeproj/project.pbxproj +6 -14
  1312. data/platform/iphone/rhorunner.xcodeproj/project.pbxproj +20 -23
  1313. data/platform/iphone/rhosynclib/rhosynclib.xcodeproj/project.pbxproj +22 -14
  1314. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/Frameworks/QtCore.framework/Versions/4/QtCore +0 -0
  1315. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/Frameworks/QtGui.framework/Versions/4/QtGui +0 -0
  1316. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/Frameworks/QtNetwork.framework/Versions/4/QtNetwork +0 -0
  1317. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/Frameworks/QtWebKit.framework/Versions/4/QtWebKit +0 -0
  1318. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/Info.plist +1 -1
  1319. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/MacOS/RhoSimulator +0 -0
  1320. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/accessible/libqtaccessiblewidgets.dylib +0 -0
  1321. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/bearer/libqcorewlanbearer.dylib +0 -0
  1322. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/bearer/libqgenericbearer.dylib +0 -0
  1323. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/codecs/libqcncodecs.dylib +0 -0
  1324. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/codecs/libqjpcodecs.dylib +0 -0
  1325. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/codecs/libqkrcodecs.dylib +0 -0
  1326. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/codecs/libqtwcodecs.dylib +0 -0
  1327. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/graphicssystems/libqtracegraphicssystem.dylib +0 -0
  1328. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/imageformats/libqgif.dylib +0 -0
  1329. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/imageformats/libqico.dylib +0 -0
  1330. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/imageformats/libqjpeg.dylib +0 -0
  1331. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/imageformats/libqmng.dylib +0 -0
  1332. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/imageformats/libqtga.dylib +0 -0
  1333. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/imageformats/libqtiff.dylib +0 -0
  1334. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/qmltooling/libqmldbg_inspector.dylib +0 -0
  1335. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/qmltooling/libqmldbg_tcp.dylib +0 -0
  1336. data/platform/osx/build/osx.rake +18 -9
  1337. data/platform/shared/RhoConnectClient/RhoConnectClient.cpp +12 -0
  1338. data/platform/shared/RhoConnectClient/RhoConnectClient.h +3 -0
  1339. data/platform/shared/common/Android.mk +1 -0
  1340. data/platform/shared/common/BundleManager.cpp +503 -47
  1341. data/platform/shared/common/ExtManager.h +4 -0
  1342. data/platform/shared/common/RhoSettingsDefs.h +3 -0
  1343. data/platform/shared/common/RhoStd.h +14 -1
  1344. data/platform/shared/common/RhodesApp.cpp +84 -137
  1345. data/platform/shared/common/RhodesApp.h +12 -7
  1346. data/platform/shared/common/RhodesAppBase.cpp +124 -2
  1347. data/platform/shared/common/RhodesAppBase.h +43 -2
  1348. data/platform/shared/common/ThreadQueue.cpp +1 -1
  1349. data/platform/shared/common/app_build_capabilities.h +0 -7
  1350. data/platform/shared/common/map/MapEngine.h +1 -0
  1351. data/platform/shared/common/push/IRhoPushClient.h +46 -0
  1352. data/platform/shared/common/push/RhoPushManager.cpp +146 -0
  1353. data/platform/shared/common/push/RhoPushManager.h +79 -0
  1354. data/platform/shared/curl/lib/curl_config.h +8 -0
  1355. data/platform/shared/curl/lib/netrc.c +2 -0
  1356. data/platform/shared/db/Android.mk +4 -1
  1357. data/platform/shared/db/DBAdapter.cpp +218 -12
  1358. data/platform/shared/db/DBAdapter.h +16 -1
  1359. data/platform/shared/db/DBAttrManager.cpp +18 -1
  1360. data/platform/shared/db/DBAttrManager.h +2 -1
  1361. data/platform/shared/db/DBImportTransaction.cpp +300 -0
  1362. data/platform/shared/db/DBImportTransaction.h +56 -0
  1363. data/platform/shared/db/DBRequestHelper.cpp +114 -0
  1364. data/platform/shared/db/DBRequestHelper.h +27 -0
  1365. data/platform/shared/logging/RhoLogConf.h +2 -0
  1366. data/platform/shared/net/AsyncHttp.cpp +4 -3
  1367. data/platform/shared/net/AsyncHttp.h +3 -2
  1368. data/platform/shared/net/CURLNetRequest.cpp +18 -5
  1369. data/platform/shared/net/HttpServer.cpp +18 -14
  1370. data/platform/shared/qt/rhodes/MainWindowCallback.h +0 -1
  1371. data/platform/shared/qt/rhodes/QtMainWindow.cpp +180 -36
  1372. data/platform/shared/qt/rhodes/QtMainWindow.h +13 -1
  1373. data/platform/shared/qt/rhodes/QtMainWindow.ui +22 -3
  1374. data/platform/shared/qt/rhodes/RhoSimulator.h +3 -0
  1375. data/platform/shared/qt/rhodes/impl/MainWindowImpl.cpp +22 -0
  1376. data/platform/shared/qt/rhodes/impl/MainWindowImpl.h +6 -0
  1377. data/platform/shared/qt/rhodes/impl/SystemImpl.cpp +15 -0
  1378. data/platform/shared/qt/rhodes/main.cpp +15 -1
  1379. data/platform/shared/qt/rholib/rholib.pro +8 -2
  1380. data/platform/shared/qt/syncengine/syncengine.pro +6 -2
  1381. data/platform/shared/ruby/ext/rho/extensions.c +2 -0
  1382. data/platform/shared/ruby/ext/rho/rhoruby.c +12 -0
  1383. data/platform/shared/ruby/ext/rho/rhoruby.h +2 -0
  1384. data/platform/shared/ruby/ext/rho/rhosupport.c +77 -38
  1385. data/platform/shared/ruby/ext/sqlite3_api/sqlite3_api_wrap.c +54 -2
  1386. data/platform/shared/ruby/ext/syncengine/syncengine.i +4 -0
  1387. data/platform/shared/ruby/ext/syncengine/syncengine_wrap.c +40 -1
  1388. data/platform/shared/ruby/ext/system/system.i +38 -4
  1389. data/platform/shared/ruby/ext/system/system_wrap.c +277 -9
  1390. data/platform/shared/ruby/iphone/ruby/config.h +28 -0
  1391. data/platform/shared/ruby/main.c +8 -0
  1392. data/platform/shared/ruby/wince/sys/timeb.c +4 -0
  1393. data/platform/shared/ruby/wince/sys/timeb.h +1 -0
  1394. data/platform/shared/rubyext/Android.mk +2 -1
  1395. data/platform/shared/rubyext/System.cpp +93 -3
  1396. data/platform/shared/rubyext/ZipFiles.cpp +65 -0
  1397. data/platform/shared/statistic/RhoProfiler.cpp +36 -6
  1398. data/platform/shared/statistic/RhoProfiler.h +3 -0
  1399. data/platform/shared/sync/ClientRegister.cpp +21 -5
  1400. data/platform/shared/sync/ClientRegister.h +4 -2
  1401. data/platform/shared/sync/ISyncProtocol.h +5 -2
  1402. data/platform/shared/sync/SyncEngine.cpp +85 -15
  1403. data/platform/shared/sync/SyncEngine.h +5 -0
  1404. data/platform/shared/sync/SyncNotify.cpp +3 -0
  1405. data/platform/shared/sync/SyncProtocol_3.h +14 -2
  1406. data/platform/shared/sync/SyncSource.cpp +238 -40
  1407. data/platform/shared/sync/SyncSource.h +2 -0
  1408. data/platform/shared/sync/SyncThread.cpp +7 -0
  1409. data/platform/shared/sync/SyncThread.h +1 -0
  1410. data/platform/shared/tcmalloc/rhomem.h +1 -1
  1411. data/platform/shared/tcmalloc/windows/port.cpp +1 -1
  1412. data/platform/shared/unzip/Android.mk +1 -1
  1413. data/platform/shared/unzip/zip.cpp +2953 -0
  1414. data/platform/shared/unzip/zip.h +255 -0
  1415. data/platform/win32/RhoSimulator/QtCore4.dll +0 -0
  1416. data/platform/win32/RhoSimulator/QtGui4.dll +0 -0
  1417. data/platform/win32/RhoSimulator/QtNetwork4.dll +0 -0
  1418. data/platform/win32/RhoSimulator/QtWebKit4.dll +0 -0
  1419. data/platform/win32/RhoSimulator/RhoSimulator.exe +0 -0
  1420. data/platform/win32/RhoSimulator/imageformats/qgif4.dll +0 -0
  1421. data/platform/win32/RhoSimulator/imageformats/qico4.dll +0 -0
  1422. data/platform/win32/RhoSimulator/imageformats/qjpeg4.dll +0 -0
  1423. data/platform/win32/RhoSimulator/imageformats/qmng4.dll +0 -0
  1424. data/platform/win32/RhoSimulator/imageformats/qsvg4.dll +0 -0
  1425. data/platform/win32/RhoSimulator/imageformats/qtiff4.dll +0 -0
  1426. data/platform/win32/RhoSimulator/phonon4.dll +0 -0
  1427. data/platform/win32/RubyWin/RubyWin.sln +2 -2
  1428. data/platform/win32/RubyWin/RubyWin.vcproj +6 -7
  1429. data/platform/wm/RhoLib/RhoLib.vcproj +33 -3
  1430. data/platform/wm/build/rhodes.nsi +64 -230
  1431. data/platform/wm/build/wm.rake +306 -93
  1432. data/platform/wm/rhodes.sln +70 -21
  1433. data/platform/wm/rhodes/DateTimePicker.h +1 -1
  1434. data/platform/wm/rhodes/IEBrowserEngine.cpp +4 -1
  1435. data/platform/wm/rhodes/MainWindow.cpp +8 -7
  1436. data/platform/wm/rhodes/MainWindow.h +1 -1
  1437. data/platform/wm/rhodes/RhoNativeViewManager.cpp +2 -2
  1438. data/platform/wm/rhodes/Rhodes.cpp +80 -30
  1439. data/platform/wm/rhodes/camera/Camera.cpp +44 -65
  1440. data/platform/wm/rhodes/camera/Camera.h +6 -0
  1441. data/platform/wm/rhodes/rho/common/ExtManager.cpp +29 -6
  1442. data/platform/wm/rhodes/rho/common/RhoClassFactory.cpp +6 -1
  1443. data/platform/wm/rhodes/rho/net/NetRequestImpl.cpp +3 -0
  1444. data/platform/wm/rhodes/rho/net/NetRequestImpl.h +1 -1
  1445. data/platform/wm/rhodes/rho/rubyext/NativeToolbarExt.cpp +5 -5
  1446. data/platform/wm/rhodes/rho/rubyext/SystemImpl.cpp +188 -29
  1447. data/platform/wm/rhodes/rho/rubyext/WebView.cpp +3 -3
  1448. data/platform/wm/rhodes/rhodes.vcproj +2284 -148
  1449. data/platform/wm/rhodes/simulator/MainWindowQt.cpp +48 -10
  1450. data/platform/wm/rhodes/simulator/MainWindowQt.h +6 -2
  1451. data/platform/wm/rhoelements.sln +122 -0
  1452. data/platform/wm/rubylib/rubylib.vcproj +4 -2
  1453. data/platform/wm/sqlite3/sqlite3.vcproj +4 -2
  1454. data/platform/wm/syncengine/syncengine.vcproj +20 -2
  1455. data/platform/wm/tcmalloc/tcmalloc.vcproj +160 -0
  1456. data/platform/wp7/RhoRubyLib/rubyext/RhoSyncEngine.cs +4 -0
  1457. data/platform/wp7/RhoRubyLib/rubyext/RhoSystem.cs +4 -0
  1458. data/rakefile.rb +173 -17
  1459. data/res/build-tools/license_rc.dll +0 -0
  1460. data/res/build-tools/win32/license_rc.dll +0 -0
  1461. data/res/generators/templates/application/app/layout.erb +7 -3
  1462. data/res/generators/templates/application/public/css/re_webkit.css +1 -1
  1463. data/res/generators/templates/application/public/css/re_webkit_flat.css +753 -0
  1464. data/res/generators/templates/extension/extensions/montana/ext/montana/platform/iphone/Montana.xcodeproj/project.pbxproj +4 -10
  1465. data/spec/framework_spec/app/spec/core/file/new_spec.rb +2 -2
  1466. data/spec/framework_spec/app/spec/core/file/open_spec.rb +6 -6
  1467. data/spec/framework_spec/app/spec/core/file/shared/open.rb +1 -1
  1468. data/spec/framework_spec/app/spec/core/file/shared/stat.rb +2 -2
  1469. data/spec/framework_spec/app/spec/core/file/stat/blksize_spec.rb +1 -1
  1470. data/spec/framework_spec/app/spec/core/file/stat/blocks_spec.rb +1 -1
  1471. data/spec/framework_spec/app/spec/core/file/stat/comparison_spec.rb +1 -1
  1472. data/spec/framework_spec/app/spec/core/file/stat/ino_spec.rb +1 -1
  1473. data/spec/framework_spec/app/spec/core/file/stat/inspect_spec.rb +1 -1
  1474. data/spec/framework_spec/app/spec/core/file/stat/mode_spec.rb +1 -1
  1475. data/spec/framework_spec/app/spec/core/file/stat/nlink_spec.rb +1 -1
  1476. data/spec/framework_spec/app/spec/core/file/stat_spec.rb +1 -1
  1477. data/spec/framework_spec/app/spec/core/file/sticky_spec.rb +2 -2
  1478. data/spec/framework_spec/app/spec/core/io/close_read_spec.rb +1 -1
  1479. data/spec/framework_spec/app/spec/core/io/close_write_spec.rb +1 -1
  1480. data/spec/framework_spec/app/spec/core/io/foreach_spec.rb +8 -8
  1481. data/spec/framework_spec/app/spec/core/io/getc_spec.rb +1 -1
  1482. data/spec/framework_spec/app/spec/core/io/gets_spec.rb +1 -1
  1483. data/spec/framework_spec/app/spec/core/io/stat_spec.rb +1 -1
  1484. data/spec/framework_spec/app/spec/core/kernel/respond_to_spec.rb +1 -1
  1485. data/spec/framework_spec/app/spec/core/time/shared/gmt_offset.rb +1 -1
  1486. data/spec/framework_spec/app/spec/library/digest/hmac_spec.rb +91 -0
  1487. data/spec/framework_spec/app/spec/library/digest/md5/file_spec.rb +1 -1
  1488. data/spec/framework_spec/app/spec/library/digest/sha256/append_spec.rb +7 -0
  1489. data/spec/framework_spec/app/spec/library/digest/sha256/block_length_spec.rb +12 -0
  1490. data/spec/framework_spec/app/spec/library/digest/sha256/digest_bang_spec.rb +13 -0
  1491. data/spec/framework_spec/app/spec/library/digest/sha256/digest_length_spec.rb +12 -0
  1492. data/spec/framework_spec/app/spec/library/digest/sha256/digest_spec.rb +32 -0
  1493. data/spec/framework_spec/app/spec/library/digest/sha256/equal_spec.rb +37 -0
  1494. data/spec/framework_spec/app/spec/library/digest/sha256/file_spec.rb +47 -0
  1495. data/spec/framework_spec/app/spec/library/digest/sha256/hexdigest_bang_spec.rb +14 -0
  1496. data/spec/framework_spec/app/spec/library/digest/sha256/hexdigest_spec.rb +32 -0
  1497. data/spec/framework_spec/app/spec/library/digest/sha256/inspect_spec.rb +12 -0
  1498. data/spec/framework_spec/app/spec/library/digest/sha256/length_spec.rb +8 -0
  1499. data/spec/framework_spec/app/spec/library/digest/sha256/reset_spec.rb +15 -0
  1500. data/spec/framework_spec/app/spec/library/digest/sha256/shared/constants.rb +15 -0
  1501. data/spec/framework_spec/app/spec/library/digest/sha256/shared/length.rb +8 -0
  1502. data/spec/framework_spec/app/spec/library/digest/sha256/shared/update.rb +7 -0
  1503. data/spec/framework_spec/app/spec/library/digest/sha256/size_spec.rb +8 -0
  1504. data/spec/framework_spec/app/spec/library/digest/sha256/to_s_spec.rb +21 -0
  1505. data/spec/framework_spec/app/spec/library/digest/sha256/update_spec.rb +7 -0
  1506. data/spec/framework_spec/app/spec/library/digest/sha384/append_spec.rb +7 -0
  1507. data/spec/framework_spec/app/spec/library/digest/sha384/block_length_spec.rb +12 -0
  1508. data/spec/framework_spec/app/spec/library/digest/sha384/digest_bang_spec.rb +13 -0
  1509. data/spec/framework_spec/app/spec/library/digest/sha384/digest_length_spec.rb +12 -0
  1510. data/spec/framework_spec/app/spec/library/digest/sha384/digest_spec.rb +32 -0
  1511. data/spec/framework_spec/app/spec/library/digest/sha384/equal_spec.rb +37 -0
  1512. data/spec/framework_spec/app/spec/library/digest/sha384/file_spec.rb +47 -0
  1513. data/spec/framework_spec/app/spec/library/digest/sha384/hexdigest_bang_spec.rb +14 -0
  1514. data/spec/framework_spec/app/spec/library/digest/sha384/hexdigest_spec.rb +32 -0
  1515. data/spec/framework_spec/app/spec/library/digest/sha384/inspect_spec.rb +12 -0
  1516. data/spec/framework_spec/app/spec/library/digest/sha384/length_spec.rb +8 -0
  1517. data/spec/framework_spec/app/spec/library/digest/sha384/reset_spec.rb +15 -0
  1518. data/spec/framework_spec/app/spec/library/digest/sha384/shared/constants.rb +16 -0
  1519. data/spec/framework_spec/app/spec/library/digest/sha384/shared/length.rb +8 -0
  1520. data/spec/framework_spec/app/spec/library/digest/sha384/shared/update.rb +7 -0
  1521. data/spec/framework_spec/app/spec/library/digest/sha384/size_spec.rb +8 -0
  1522. data/spec/framework_spec/app/spec/library/digest/sha384/to_s_spec.rb +21 -0
  1523. data/spec/framework_spec/app/spec/library/digest/sha384/update_spec.rb +7 -0
  1524. data/spec/framework_spec/app/spec/library/digest/sha512/append_spec.rb +7 -0
  1525. data/spec/framework_spec/app/spec/library/digest/sha512/block_length_spec.rb +12 -0
  1526. data/spec/framework_spec/app/spec/library/digest/sha512/digest_bang_spec.rb +13 -0
  1527. data/spec/framework_spec/app/spec/library/digest/sha512/digest_length_spec.rb +12 -0
  1528. data/spec/framework_spec/app/spec/library/digest/sha512/digest_spec.rb +32 -0
  1529. data/spec/framework_spec/app/spec/library/digest/sha512/equal_spec.rb +37 -0
  1530. data/spec/framework_spec/app/spec/library/digest/sha512/file_spec.rb +47 -0
  1531. data/spec/framework_spec/app/spec/library/digest/sha512/hexdigest_bang_spec.rb +14 -0
  1532. data/spec/framework_spec/app/spec/library/digest/sha512/hexdigest_spec.rb +32 -0
  1533. data/spec/framework_spec/app/spec/library/digest/sha512/inspect_spec.rb +12 -0
  1534. data/spec/framework_spec/app/spec/library/digest/sha512/length_spec.rb +8 -0
  1535. data/spec/framework_spec/app/spec/library/digest/sha512/reset_spec.rb +15 -0
  1536. data/spec/framework_spec/app/spec/library/digest/sha512/shared/constants.rb +15 -0
  1537. data/spec/framework_spec/app/spec/library/digest/sha512/shared/length.rb +8 -0
  1538. data/spec/framework_spec/app/spec/library/digest/sha512/shared/update.rb +7 -0
  1539. data/spec/framework_spec/app/spec/library/digest/sha512/size_spec.rb +8 -0
  1540. data/spec/framework_spec/app/spec/library/digest/sha512/to_s_spec.rb +21 -0
  1541. data/spec/framework_spec/app/spec/library/digest/sha512/update_spec.rb +7 -0
  1542. data/spec/framework_spec/app/spec/library/ezcrypto/ezcrypto_spec.rb +13 -0
  1543. data/spec/framework_spec/app/spec/library/net/ftp/nlst_spec.rb +1 -1
  1544. data/spec/framework_spec/app/spec/library/net/ftp/retrbinary_spec.rb +1 -1
  1545. data/spec/framework_spec/app/spec/library/net/ftp/retrlines_spec.rb +1 -1
  1546. data/spec/framework_spec/app/spec/library/net/ftp/shared/getbinaryfile.rb +1 -1
  1547. data/spec/framework_spec/app/spec/library/net/ftp/shared/gettextfile.rb +1 -1
  1548. data/spec/framework_spec/app/spec/library/net/ftp/shared/list.rb +1 -1
  1549. data/spec/framework_spec/app/spec/library/net/ftp/shared/putbinaryfile.rb +1 -1
  1550. data/spec/framework_spec/app/spec/library/net/ftp/shared/puttextfile.rb +1 -1
  1551. data/spec/framework_spec/app/spec/library/net/ftp/storbinary_spec.rb +1 -1
  1552. data/spec/framework_spec/app/spec/library/net/ftp/storlines_spec.rb +1 -1
  1553. data/spec/framework_spec/app/spec/library/openssl/cipher_spec.rb +19 -0
  1554. data/spec/framework_spec/app/spec/library/openssl/config/freeze_spec.rb +21 -0
  1555. data/spec/framework_spec/app/spec/library/openssl/hmac/digest_spec.rb +18 -0
  1556. data/spec/framework_spec/app/spec/library/openssl/hmac/hexdigest_spec.rb +18 -0
  1557. data/spec/framework_spec/app/spec/library/openssl/random/pseudo_bytes_spec.rb +7 -0
  1558. data/spec/framework_spec/app/spec/library/openssl/random/random_bytes_spec.rb +7 -0
  1559. data/spec/framework_spec/app/spec/library/openssl/random/shared/random_bytes.rb +29 -0
  1560. data/spec/framework_spec/app/spec/library/openssl/shared/constants.rb +10 -0
  1561. data/spec/framework_spec/app/spec/library/zlib/adler32_spec.rb +46 -0
  1562. data/spec/framework_spec/app/spec/library/zlib/crc32_spec.rb +52 -0
  1563. data/spec/framework_spec/app/spec/library/zlib/crc_table_spec.rb +11 -0
  1564. data/spec/framework_spec/app/spec/library/zlib/deflate/append_spec.rb +1 -0
  1565. data/spec/framework_spec/app/spec/library/zlib/deflate/deflate_spec.rb +49 -0
  1566. data/spec/framework_spec/app/spec/library/zlib/deflate/flush_spec.rb +1 -0
  1567. data/spec/framework_spec/app/spec/library/zlib/deflate/initialize_copy_spec.rb +1 -0
  1568. data/spec/framework_spec/app/spec/library/zlib/deflate/new_spec.rb +1 -0
  1569. data/spec/framework_spec/app/spec/library/zlib/deflate/params_spec.rb +20 -0
  1570. data/spec/framework_spec/app/spec/library/zlib/deflate/set_dictionary_spec.rb +14 -0
  1571. data/spec/framework_spec/app/spec/library/zlib/gzipfile/close_spec.rb +23 -0
  1572. data/spec/framework_spec/app/spec/library/zlib/gzipfile/closed_spec.rb +17 -0
  1573. data/spec/framework_spec/app/spec/library/zlib/gzipfile/comment_spec.rb +27 -0
  1574. data/spec/framework_spec/app/spec/library/zlib/gzipfile/crc_spec.rb +1 -0
  1575. data/spec/framework_spec/app/spec/library/zlib/gzipfile/finish_spec.rb +1 -0
  1576. data/spec/framework_spec/app/spec/library/zlib/gzipfile/level_spec.rb +1 -0
  1577. data/spec/framework_spec/app/spec/library/zlib/gzipfile/mtime_spec.rb +1 -0
  1578. data/spec/framework_spec/app/spec/library/zlib/gzipfile/orig_name_spec.rb +27 -0
  1579. data/spec/framework_spec/app/spec/library/zlib/gzipfile/os_code_spec.rb +1 -0
  1580. data/spec/framework_spec/app/spec/library/zlib/gzipfile/sync_spec.rb +1 -0
  1581. data/spec/framework_spec/app/spec/library/zlib/gzipfile/to_io_spec.rb +1 -0
  1582. data/spec/framework_spec/app/spec/library/zlib/gzipfile/wrap_spec.rb +1 -0
  1583. data/spec/framework_spec/app/spec/library/zlib/gzipreader/each_byte_spec.rb +33 -0
  1584. data/spec/framework_spec/app/spec/library/zlib/gzipreader/each_line_spec.rb +1 -0
  1585. data/spec/framework_spec/app/spec/library/zlib/gzipreader/each_spec.rb +1 -0
  1586. data/spec/framework_spec/app/spec/library/zlib/gzipreader/eof_spec.rb +55 -0
  1587. data/spec/framework_spec/app/spec/library/zlib/gzipreader/getc_spec.rb +55 -0
  1588. data/spec/framework_spec/app/spec/library/zlib/gzipreader/gets_spec.rb +1 -0
  1589. data/spec/framework_spec/app/spec/library/zlib/gzipreader/lineno_spec.rb +1 -0
  1590. data/spec/framework_spec/app/spec/library/zlib/gzipreader/new_spec.rb +1 -0
  1591. data/spec/framework_spec/app/spec/library/zlib/gzipreader/open_spec.rb +1 -0
  1592. data/spec/framework_spec/app/spec/library/zlib/gzipreader/pos_spec.rb +26 -0
  1593. data/spec/framework_spec/app/spec/library/zlib/gzipreader/read_spec.rb +58 -0
  1594. data/spec/framework_spec/app/spec/library/zlib/gzipreader/readchar_spec.rb +1 -0
  1595. data/spec/framework_spec/app/spec/library/zlib/gzipreader/readline_spec.rb +1 -0
  1596. data/spec/framework_spec/app/spec/library/zlib/gzipreader/readlines_spec.rb +1 -0
  1597. data/spec/framework_spec/app/spec/library/zlib/gzipreader/rewind_spec.rb +47 -0
  1598. data/spec/framework_spec/app/spec/library/zlib/gzipreader/tell_spec.rb +1 -0
  1599. data/spec/framework_spec/app/spec/library/zlib/gzipreader/ungetc_spec.rb +1 -0
  1600. data/spec/framework_spec/app/spec/library/zlib/gzipreader/unused_spec.rb +1 -0
  1601. data/spec/framework_spec/app/spec/library/zlib/gzipwriter/append_spec.rb +1 -0
  1602. data/spec/framework_spec/app/spec/library/zlib/gzipwriter/comment_spec.rb +1 -0
  1603. data/spec/framework_spec/app/spec/library/zlib/gzipwriter/flush_spec.rb +1 -0
  1604. data/spec/framework_spec/app/spec/library/zlib/gzipwriter/mtime_spec.rb +41 -0
  1605. data/spec/framework_spec/app/spec/library/zlib/gzipwriter/new_spec.rb +1 -0
  1606. data/spec/framework_spec/app/spec/library/zlib/gzipwriter/open_spec.rb +1 -0
  1607. data/spec/framework_spec/app/spec/library/zlib/gzipwriter/orig_name_spec.rb +1 -0
  1608. data/spec/framework_spec/app/spec/library/zlib/gzipwriter/pos_spec.rb +1 -0
  1609. data/spec/framework_spec/app/spec/library/zlib/gzipwriter/print_spec.rb +1 -0
  1610. data/spec/framework_spec/app/spec/library/zlib/gzipwriter/printf_spec.rb +1 -0
  1611. data/spec/framework_spec/app/spec/library/zlib/gzipwriter/putc_spec.rb +1 -0
  1612. data/spec/framework_spec/app/spec/library/zlib/gzipwriter/puts_spec.rb +1 -0
  1613. data/spec/framework_spec/app/spec/library/zlib/gzipwriter/tell_spec.rb +1 -0
  1614. data/spec/framework_spec/app/spec/library/zlib/gzipwriter/write_spec.rb +24 -0
  1615. data/spec/framework_spec/app/spec/library/zlib/inflate/append_spec.rb +60 -0
  1616. data/spec/framework_spec/app/spec/library/zlib/inflate/inflate_spec.rb +109 -0
  1617. data/spec/framework_spec/app/spec/library/zlib/inflate/new_spec.rb +1 -0
  1618. data/spec/framework_spec/app/spec/library/zlib/inflate/set_dictionary_spec.rb +20 -0
  1619. data/spec/framework_spec/app/spec/library/zlib/inflate/sync_point_spec.rb +1 -0
  1620. data/spec/framework_spec/app/spec/library/zlib/inflate/sync_spec.rb +1 -0
  1621. data/spec/framework_spec/app/spec/library/zlib/zlib_version_spec.rb +1 -0
  1622. data/spec/framework_spec/app/spec/library/zlib/zstream/adler_spec.rb +1 -0
  1623. data/spec/framework_spec/app/spec/library/zlib/zstream/avail_in_spec.rb +1 -0
  1624. data/spec/framework_spec/app/spec/library/zlib/zstream/avail_out_spec.rb +1 -0
  1625. data/spec/framework_spec/app/spec/library/zlib/zstream/close_spec.rb +1 -0
  1626. data/spec/framework_spec/app/spec/library/zlib/zstream/closed_spec.rb +1 -0
  1627. data/spec/framework_spec/app/spec/library/zlib/zstream/data_type_spec.rb +1 -0
  1628. data/spec/framework_spec/app/spec/library/zlib/zstream/end_spec.rb +1 -0
  1629. data/spec/framework_spec/app/spec/library/zlib/zstream/ended_spec.rb +1 -0
  1630. data/spec/framework_spec/app/spec/library/zlib/zstream/finish_spec.rb +1 -0
  1631. data/spec/framework_spec/app/spec/library/zlib/zstream/finished_spec.rb +1 -0
  1632. data/spec/framework_spec/app/spec/library/zlib/zstream/flush_next_in_spec.rb +1 -0
  1633. data/spec/framework_spec/app/spec/library/zlib/zstream/flush_next_out_spec.rb +16 -0
  1634. data/spec/framework_spec/app/spec/library/zlib/zstream/reset_spec.rb +1 -0
  1635. data/spec/framework_spec/app/spec/library/zlib/zstream/stream_end_spec.rb +1 -0
  1636. data/spec/framework_spec/app/spec/library/zlib/zstream/total_in_spec.rb +1 -0
  1637. data/spec/framework_spec/app/spec/library/zlib/zstream/total_out_spec.rb +1 -0
  1638. data/spec/framework_spec/app/spec/shared/file/executable_real.rb +1 -1
  1639. data/spec/framework_spec/app/spec/shared/file/file.rb +1 -1
  1640. data/spec/framework_spec/app/spec_runner.rb +6 -5
  1641. data/spec/framework_spec/build.yml +4 -1
  1642. data/spec/phone_spec/app/BlobBulkTest/blob_bulk_test.png +0 -0
  1643. data/spec/phone_spec/app/BlobBulkTest/blob_bulk_test.rb +11 -0
  1644. data/spec/phone_spec/app/BlobBulkTest_s/blob_bulk_test_s.png +0 -0
  1645. data/spec/phone_spec/app/BlobBulkTest_s/blob_bulk_test_s.rb +11 -0
  1646. data/spec/phone_spec/app/Data/invalid_import_db.zip +0 -0
  1647. data/spec/phone_spec/app/Data/valid_import_db.zip +0 -0
  1648. data/spec/phone_spec/app/spec/asynchttp_spec.rb +1 -1
  1649. data/spec/phone_spec/app/spec/blob_bulksync_spec.rb +160 -0
  1650. data/spec/phone_spec/app/spec/bulksync_spec.rb +51 -1
  1651. data/spec/phone_spec/app/spec/bundle_update_spec.rb +85 -0
  1652. data/spec/phone_spec/app/spec/database_spec.rb +174 -0
  1653. data/spec/phone_spec/app/spec/events_spec.rb +4 -4
  1654. data/spec/phone_spec/app/spec/json_spec.rb +1 -1
  1655. data/spec/phone_spec/app/spec/rho_spec.rb +88 -12
  1656. data/spec/phone_spec/app/spec/rhofile_spec.rb +1 -1
  1657. data/spec/phone_spec/app/spec/rhom_object_spec.rb +8 -5
  1658. data/spec/phone_spec/app/spec/syncengine_spec.rb +281 -18
  1659. data/spec/phone_spec/app/spec/uri_spec.rb +5 -5
  1660. data/spec/phone_spec/app/spec_runner.rb +16 -9
  1661. data/spec/phone_spec/build.yml +2 -1
  1662. data/spec/phone_spec/public/file_for_replace.txt +1 -0
  1663. data/spec/phone_spec/public/file_to_remove.png +0 -0
  1664. data/spec/phone_spec/public/folder_to_remove.png +0 -0
  1665. data/spec/phone_spec/public/folder_to_remove/switch.png +0 -0
  1666. data/spec/phone_spec/public/partial_update_bundle/upgrade_bundle_partial.zip +0 -0
  1667. data/spec/phone_spec/upgrade_package_add_files.txt +2 -0
  1668. data/spec/phone_spec/upgrade_package_remove_files.txt +2 -0
  1669. data/version +1 -1
  1670. metadata +1384 -12
  1671. data/Manifest.txt +0 -8054
  1672. data/doc/alert-api.txt +0 -51
  1673. data/doc/files.txt +0 -4
  1674. data/doc/rhodes-api.txt +0 -147
  1675. data/doc/scanner.txt +0 -507
  1676. data/doc/timer-api.txt +0 -39
  1677. data/doc/tutorial.txt +0 -130
  1678. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/WebkitExtension.java +0 -53
@@ -0,0 +1,2578 @@
1
+ /* ssl/t1_lib.c */
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-2007 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
+ #include <stdio.h>
113
+ #include <openssl/objects.h>
114
+ #include <openssl/evp.h>
115
+ #include <openssl/hmac.h>
116
+ #include <openssl/ocsp.h>
117
+ #include <openssl/rand.h>
118
+ #include "ssl_locl.h"
119
+
120
+ const char tls1_version_str[]="TLSv1" OPENSSL_VERSION_PTEXT;
121
+
122
+ #ifndef OPENSSL_NO_TLSEXT
123
+ static int tls_decrypt_ticket(SSL *s, const unsigned char *tick, int ticklen,
124
+ const unsigned char *sess_id, int sesslen,
125
+ SSL_SESSION **psess);
126
+ #endif
127
+
128
+ SSL3_ENC_METHOD TLSv1_enc_data={
129
+ tls1_enc,
130
+ tls1_mac,
131
+ tls1_setup_key_block,
132
+ tls1_generate_master_secret,
133
+ tls1_change_cipher_state,
134
+ tls1_final_finish_mac,
135
+ TLS1_FINISH_MAC_LENGTH,
136
+ tls1_cert_verify_mac,
137
+ TLS_MD_CLIENT_FINISH_CONST,TLS_MD_CLIENT_FINISH_CONST_SIZE,
138
+ TLS_MD_SERVER_FINISH_CONST,TLS_MD_SERVER_FINISH_CONST_SIZE,
139
+ tls1_alert_code,
140
+ tls1_export_keying_material,
141
+ };
142
+
143
+ long tls1_default_timeout(void)
144
+ {
145
+ /* 2 hours, the 24 hours mentioned in the TLSv1 spec
146
+ * is way too long for http, the cache would over fill */
147
+ return(60*60*2);
148
+ }
149
+
150
+ int tls1_new(SSL *s)
151
+ {
152
+ if (!ssl3_new(s)) return(0);
153
+ s->method->ssl_clear(s);
154
+ return(1);
155
+ }
156
+
157
+ void tls1_free(SSL *s)
158
+ {
159
+ #ifndef OPENSSL_NO_TLSEXT
160
+ if (s->tlsext_session_ticket)
161
+ {
162
+ OPENSSL_free(s->tlsext_session_ticket);
163
+ }
164
+ #endif /* OPENSSL_NO_TLSEXT */
165
+ ssl3_free(s);
166
+ }
167
+
168
+ void tls1_clear(SSL *s)
169
+ {
170
+ ssl3_clear(s);
171
+ s->version = s->method->version;
172
+ }
173
+
174
+ #ifndef OPENSSL_NO_EC
175
+
176
+ static int nid_list[] =
177
+ {
178
+ NID_sect163k1, /* sect163k1 (1) */
179
+ NID_sect163r1, /* sect163r1 (2) */
180
+ NID_sect163r2, /* sect163r2 (3) */
181
+ NID_sect193r1, /* sect193r1 (4) */
182
+ NID_sect193r2, /* sect193r2 (5) */
183
+ NID_sect233k1, /* sect233k1 (6) */
184
+ NID_sect233r1, /* sect233r1 (7) */
185
+ NID_sect239k1, /* sect239k1 (8) */
186
+ NID_sect283k1, /* sect283k1 (9) */
187
+ NID_sect283r1, /* sect283r1 (10) */
188
+ NID_sect409k1, /* sect409k1 (11) */
189
+ NID_sect409r1, /* sect409r1 (12) */
190
+ NID_sect571k1, /* sect571k1 (13) */
191
+ NID_sect571r1, /* sect571r1 (14) */
192
+ NID_secp160k1, /* secp160k1 (15) */
193
+ NID_secp160r1, /* secp160r1 (16) */
194
+ NID_secp160r2, /* secp160r2 (17) */
195
+ NID_secp192k1, /* secp192k1 (18) */
196
+ NID_X9_62_prime192v1, /* secp192r1 (19) */
197
+ NID_secp224k1, /* secp224k1 (20) */
198
+ NID_secp224r1, /* secp224r1 (21) */
199
+ NID_secp256k1, /* secp256k1 (22) */
200
+ NID_X9_62_prime256v1, /* secp256r1 (23) */
201
+ NID_secp384r1, /* secp384r1 (24) */
202
+ NID_secp521r1 /* secp521r1 (25) */
203
+ };
204
+
205
+ static int pref_list[] =
206
+ {
207
+ NID_sect571r1, /* sect571r1 (14) */
208
+ NID_sect571k1, /* sect571k1 (13) */
209
+ NID_secp521r1, /* secp521r1 (25) */
210
+ NID_sect409k1, /* sect409k1 (11) */
211
+ NID_sect409r1, /* sect409r1 (12) */
212
+ NID_secp384r1, /* secp384r1 (24) */
213
+ NID_sect283k1, /* sect283k1 (9) */
214
+ NID_sect283r1, /* sect283r1 (10) */
215
+ NID_secp256k1, /* secp256k1 (22) */
216
+ NID_X9_62_prime256v1, /* secp256r1 (23) */
217
+ NID_sect239k1, /* sect239k1 (8) */
218
+ NID_sect233k1, /* sect233k1 (6) */
219
+ NID_sect233r1, /* sect233r1 (7) */
220
+ NID_secp224k1, /* secp224k1 (20) */
221
+ NID_secp224r1, /* secp224r1 (21) */
222
+ NID_sect193r1, /* sect193r1 (4) */
223
+ NID_sect193r2, /* sect193r2 (5) */
224
+ NID_secp192k1, /* secp192k1 (18) */
225
+ NID_X9_62_prime192v1, /* secp192r1 (19) */
226
+ NID_sect163k1, /* sect163k1 (1) */
227
+ NID_sect163r1, /* sect163r1 (2) */
228
+ NID_sect163r2, /* sect163r2 (3) */
229
+ NID_secp160k1, /* secp160k1 (15) */
230
+ NID_secp160r1, /* secp160r1 (16) */
231
+ NID_secp160r2, /* secp160r2 (17) */
232
+ };
233
+
234
+ int tls1_ec_curve_id2nid(int curve_id)
235
+ {
236
+ /* ECC curves from draft-ietf-tls-ecc-12.txt (Oct. 17, 2005) */
237
+ if ((curve_id < 1) || ((unsigned int)curve_id >
238
+ sizeof(nid_list)/sizeof(nid_list[0])))
239
+ return 0;
240
+ return nid_list[curve_id-1];
241
+ }
242
+
243
+ int tls1_ec_nid2curve_id(int nid)
244
+ {
245
+ /* ECC curves from draft-ietf-tls-ecc-12.txt (Oct. 17, 2005) */
246
+ switch (nid)
247
+ {
248
+ case NID_sect163k1: /* sect163k1 (1) */
249
+ return 1;
250
+ case NID_sect163r1: /* sect163r1 (2) */
251
+ return 2;
252
+ case NID_sect163r2: /* sect163r2 (3) */
253
+ return 3;
254
+ case NID_sect193r1: /* sect193r1 (4) */
255
+ return 4;
256
+ case NID_sect193r2: /* sect193r2 (5) */
257
+ return 5;
258
+ case NID_sect233k1: /* sect233k1 (6) */
259
+ return 6;
260
+ case NID_sect233r1: /* sect233r1 (7) */
261
+ return 7;
262
+ case NID_sect239k1: /* sect239k1 (8) */
263
+ return 8;
264
+ case NID_sect283k1: /* sect283k1 (9) */
265
+ return 9;
266
+ case NID_sect283r1: /* sect283r1 (10) */
267
+ return 10;
268
+ case NID_sect409k1: /* sect409k1 (11) */
269
+ return 11;
270
+ case NID_sect409r1: /* sect409r1 (12) */
271
+ return 12;
272
+ case NID_sect571k1: /* sect571k1 (13) */
273
+ return 13;
274
+ case NID_sect571r1: /* sect571r1 (14) */
275
+ return 14;
276
+ case NID_secp160k1: /* secp160k1 (15) */
277
+ return 15;
278
+ case NID_secp160r1: /* secp160r1 (16) */
279
+ return 16;
280
+ case NID_secp160r2: /* secp160r2 (17) */
281
+ return 17;
282
+ case NID_secp192k1: /* secp192k1 (18) */
283
+ return 18;
284
+ case NID_X9_62_prime192v1: /* secp192r1 (19) */
285
+ return 19;
286
+ case NID_secp224k1: /* secp224k1 (20) */
287
+ return 20;
288
+ case NID_secp224r1: /* secp224r1 (21) */
289
+ return 21;
290
+ case NID_secp256k1: /* secp256k1 (22) */
291
+ return 22;
292
+ case NID_X9_62_prime256v1: /* secp256r1 (23) */
293
+ return 23;
294
+ case NID_secp384r1: /* secp384r1 (24) */
295
+ return 24;
296
+ case NID_secp521r1: /* secp521r1 (25) */
297
+ return 25;
298
+ default:
299
+ return 0;
300
+ }
301
+ }
302
+ #endif /* OPENSSL_NO_EC */
303
+
304
+ #ifndef OPENSSL_NO_TLSEXT
305
+
306
+ /* List of supported signature algorithms and hashes. Should make this
307
+ * customisable at some point, for now include everything we support.
308
+ */
309
+
310
+ #ifdef OPENSSL_NO_RSA
311
+ #define tlsext_sigalg_rsa(md) /* */
312
+ #else
313
+ #define tlsext_sigalg_rsa(md) md, TLSEXT_signature_rsa,
314
+ #endif
315
+
316
+ #ifdef OPENSSL_NO_DSA
317
+ #define tlsext_sigalg_dsa(md) /* */
318
+ #else
319
+ #define tlsext_sigalg_dsa(md) md, TLSEXT_signature_dsa,
320
+ #endif
321
+
322
+ #ifdef OPENSSL_NO_ECDSA
323
+ #define tlsext_sigalg_ecdsa(md) /* */
324
+ #else
325
+ #define tlsext_sigalg_ecdsa(md) md, TLSEXT_signature_ecdsa,
326
+ #endif
327
+
328
+ #define tlsext_sigalg(md) \
329
+ tlsext_sigalg_rsa(md) \
330
+ tlsext_sigalg_dsa(md) \
331
+ tlsext_sigalg_ecdsa(md)
332
+
333
+ static unsigned char tls12_sigalgs[] = {
334
+ #ifndef OPENSSL_NO_SHA512
335
+ tlsext_sigalg(TLSEXT_hash_sha512)
336
+ tlsext_sigalg(TLSEXT_hash_sha384)
337
+ #endif
338
+ #ifndef OPENSSL_NO_SHA256
339
+ tlsext_sigalg(TLSEXT_hash_sha256)
340
+ tlsext_sigalg(TLSEXT_hash_sha224)
341
+ #endif
342
+ #ifndef OPENSSL_NO_SHA
343
+ tlsext_sigalg(TLSEXT_hash_sha1)
344
+ #endif
345
+ #ifndef OPENSSL_NO_MD5
346
+ tlsext_sigalg_rsa(TLSEXT_hash_md5)
347
+ #endif
348
+ };
349
+
350
+ int tls12_get_req_sig_algs(SSL *s, unsigned char *p)
351
+ {
352
+ size_t slen = sizeof(tls12_sigalgs);
353
+ #ifdef OPENSSL_FIPS
354
+ /* If FIPS mode don't include MD5 which is last */
355
+ if (FIPS_mode())
356
+ slen -= 2;
357
+ #endif
358
+ if (p)
359
+ memcpy(p, tls12_sigalgs, slen);
360
+ return (int)slen;
361
+ }
362
+
363
+ unsigned char *ssl_add_clienthello_tlsext(SSL *s, unsigned char *p, unsigned char *limit)
364
+ {
365
+ int extdatalen=0;
366
+ unsigned char *ret = p;
367
+
368
+ /* don't add extensions for SSLv3 unless doing secure renegotiation */
369
+ if (s->client_version == SSL3_VERSION
370
+ && !s->s3->send_connection_binding)
371
+ return p;
372
+
373
+ ret+=2;
374
+
375
+ if (ret>=limit) return NULL; /* this really never occurs, but ... */
376
+
377
+ if (s->tlsext_hostname != NULL)
378
+ {
379
+ /* Add TLS extension servername to the Client Hello message */
380
+ unsigned long size_str;
381
+ long lenmax;
382
+
383
+ /* check for enough space.
384
+ 4 for the servername type and entension length
385
+ 2 for servernamelist length
386
+ 1 for the hostname type
387
+ 2 for hostname length
388
+ + hostname length
389
+ */
390
+
391
+ if ((lenmax = limit - ret - 9) < 0
392
+ || (size_str = strlen(s->tlsext_hostname)) > (unsigned long)lenmax)
393
+ return NULL;
394
+
395
+ /* extension type and length */
396
+ s2n(TLSEXT_TYPE_server_name,ret);
397
+ s2n(size_str+5,ret);
398
+
399
+ /* length of servername list */
400
+ s2n(size_str+3,ret);
401
+
402
+ /* hostname type, length and hostname */
403
+ *(ret++) = (unsigned char) TLSEXT_NAMETYPE_host_name;
404
+ s2n(size_str,ret);
405
+ memcpy(ret, s->tlsext_hostname, size_str);
406
+ ret+=size_str;
407
+ }
408
+
409
+ /* Add RI if renegotiating */
410
+ if (s->renegotiate)
411
+ {
412
+ int el;
413
+
414
+ if(!ssl_add_clienthello_renegotiate_ext(s, 0, &el, 0))
415
+ {
416
+ SSLerr(SSL_F_SSL_ADD_CLIENTHELLO_TLSEXT, ERR_R_INTERNAL_ERROR);
417
+ return NULL;
418
+ }
419
+
420
+ if((limit - p - 4 - el) < 0) return NULL;
421
+
422
+ s2n(TLSEXT_TYPE_renegotiate,ret);
423
+ s2n(el,ret);
424
+
425
+ if(!ssl_add_clienthello_renegotiate_ext(s, ret, &el, el))
426
+ {
427
+ SSLerr(SSL_F_SSL_ADD_CLIENTHELLO_TLSEXT, ERR_R_INTERNAL_ERROR);
428
+ return NULL;
429
+ }
430
+
431
+ ret += el;
432
+ }
433
+
434
+ #ifndef OPENSSL_NO_SRP
435
+ /* Add SRP username if there is one */
436
+ if (s->srp_ctx.login != NULL)
437
+ { /* Add TLS extension SRP username to the Client Hello message */
438
+
439
+ int login_len = strlen(s->srp_ctx.login);
440
+ if (login_len > 255 || login_len == 0)
441
+ {
442
+ SSLerr(SSL_F_SSL_ADD_CLIENTHELLO_TLSEXT, ERR_R_INTERNAL_ERROR);
443
+ return NULL;
444
+ }
445
+
446
+ /* check for enough space.
447
+ 4 for the srp type type and entension length
448
+ 1 for the srp user identity
449
+ + srp user identity length
450
+ */
451
+ if ((limit - ret - 5 - login_len) < 0) return NULL;
452
+
453
+ /* fill in the extension */
454
+ s2n(TLSEXT_TYPE_srp,ret);
455
+ s2n(login_len+1,ret);
456
+ (*ret++) = (unsigned char) login_len;
457
+ memcpy(ret, s->srp_ctx.login, login_len);
458
+ ret+=login_len;
459
+ }
460
+ #endif
461
+
462
+ #ifndef OPENSSL_NO_EC
463
+ if (s->tlsext_ecpointformatlist != NULL &&
464
+ s->version != DTLS1_VERSION)
465
+ {
466
+ /* Add TLS extension ECPointFormats to the ClientHello message */
467
+ long lenmax;
468
+
469
+ if ((lenmax = limit - ret - 5) < 0) return NULL;
470
+ if (s->tlsext_ecpointformatlist_length > (unsigned long)lenmax) return NULL;
471
+ if (s->tlsext_ecpointformatlist_length > 255)
472
+ {
473
+ SSLerr(SSL_F_SSL_ADD_CLIENTHELLO_TLSEXT, ERR_R_INTERNAL_ERROR);
474
+ return NULL;
475
+ }
476
+
477
+ s2n(TLSEXT_TYPE_ec_point_formats,ret);
478
+ s2n(s->tlsext_ecpointformatlist_length + 1,ret);
479
+ *(ret++) = (unsigned char) s->tlsext_ecpointformatlist_length;
480
+ memcpy(ret, s->tlsext_ecpointformatlist, s->tlsext_ecpointformatlist_length);
481
+ ret+=s->tlsext_ecpointformatlist_length;
482
+ }
483
+ if (s->tlsext_ellipticcurvelist != NULL &&
484
+ s->version != DTLS1_VERSION)
485
+ {
486
+ /* Add TLS extension EllipticCurves to the ClientHello message */
487
+ long lenmax;
488
+
489
+ if ((lenmax = limit - ret - 6) < 0) return NULL;
490
+ if (s->tlsext_ellipticcurvelist_length > (unsigned long)lenmax) return NULL;
491
+ if (s->tlsext_ellipticcurvelist_length > 65532)
492
+ {
493
+ SSLerr(SSL_F_SSL_ADD_CLIENTHELLO_TLSEXT, ERR_R_INTERNAL_ERROR);
494
+ return NULL;
495
+ }
496
+
497
+ s2n(TLSEXT_TYPE_elliptic_curves,ret);
498
+ s2n(s->tlsext_ellipticcurvelist_length + 2, ret);
499
+
500
+ /* NB: draft-ietf-tls-ecc-12.txt uses a one-byte prefix for
501
+ * elliptic_curve_list, but the examples use two bytes.
502
+ * http://www1.ietf.org/mail-archive/web/tls/current/msg00538.html
503
+ * resolves this to two bytes.
504
+ */
505
+ s2n(s->tlsext_ellipticcurvelist_length, ret);
506
+ memcpy(ret, s->tlsext_ellipticcurvelist, s->tlsext_ellipticcurvelist_length);
507
+ ret+=s->tlsext_ellipticcurvelist_length;
508
+ }
509
+ #endif /* OPENSSL_NO_EC */
510
+
511
+ if (!(SSL_get_options(s) & SSL_OP_NO_TICKET))
512
+ {
513
+ int ticklen;
514
+ if (!s->new_session && s->session && s->session->tlsext_tick)
515
+ ticklen = s->session->tlsext_ticklen;
516
+ else if (s->session && s->tlsext_session_ticket &&
517
+ s->tlsext_session_ticket->data)
518
+ {
519
+ ticklen = s->tlsext_session_ticket->length;
520
+ s->session->tlsext_tick = OPENSSL_malloc(ticklen);
521
+ if (!s->session->tlsext_tick)
522
+ return NULL;
523
+ memcpy(s->session->tlsext_tick,
524
+ s->tlsext_session_ticket->data,
525
+ ticklen);
526
+ s->session->tlsext_ticklen = ticklen;
527
+ }
528
+ else
529
+ ticklen = 0;
530
+ if (ticklen == 0 && s->tlsext_session_ticket &&
531
+ s->tlsext_session_ticket->data == NULL)
532
+ goto skip_ext;
533
+ /* Check for enough room 2 for extension type, 2 for len
534
+ * rest for ticket
535
+ */
536
+ if ((long)(limit - ret - 4 - ticklen) < 0) return NULL;
537
+ s2n(TLSEXT_TYPE_session_ticket,ret);
538
+ s2n(ticklen,ret);
539
+ if (ticklen)
540
+ {
541
+ memcpy(ret, s->session->tlsext_tick, ticklen);
542
+ ret += ticklen;
543
+ }
544
+ }
545
+ skip_ext:
546
+
547
+ if (TLS1_get_client_version(s) >= TLS1_2_VERSION)
548
+ {
549
+ if ((size_t)(limit - ret) < sizeof(tls12_sigalgs) + 6)
550
+ return NULL;
551
+ s2n(TLSEXT_TYPE_signature_algorithms,ret);
552
+ s2n(sizeof(tls12_sigalgs) + 2, ret);
553
+ s2n(sizeof(tls12_sigalgs), ret);
554
+ memcpy(ret, tls12_sigalgs, sizeof(tls12_sigalgs));
555
+ ret += sizeof(tls12_sigalgs);
556
+ }
557
+
558
+ #ifdef TLSEXT_TYPE_opaque_prf_input
559
+ if (s->s3->client_opaque_prf_input != NULL &&
560
+ s->version != DTLS1_VERSION)
561
+ {
562
+ size_t col = s->s3->client_opaque_prf_input_len;
563
+
564
+ if ((long)(limit - ret - 6 - col < 0))
565
+ return NULL;
566
+ if (col > 0xFFFD) /* can't happen */
567
+ return NULL;
568
+
569
+ s2n(TLSEXT_TYPE_opaque_prf_input, ret);
570
+ s2n(col + 2, ret);
571
+ s2n(col, ret);
572
+ memcpy(ret, s->s3->client_opaque_prf_input, col);
573
+ ret += col;
574
+ }
575
+ #endif
576
+
577
+ if (s->tlsext_status_type == TLSEXT_STATUSTYPE_ocsp &&
578
+ s->version != DTLS1_VERSION)
579
+ {
580
+ int i;
581
+ long extlen, idlen, itmp;
582
+ OCSP_RESPID *id;
583
+
584
+ idlen = 0;
585
+ for (i = 0; i < sk_OCSP_RESPID_num(s->tlsext_ocsp_ids); i++)
586
+ {
587
+ id = sk_OCSP_RESPID_value(s->tlsext_ocsp_ids, i);
588
+ itmp = i2d_OCSP_RESPID(id, NULL);
589
+ if (itmp <= 0)
590
+ return NULL;
591
+ idlen += itmp + 2;
592
+ }
593
+
594
+ if (s->tlsext_ocsp_exts)
595
+ {
596
+ extlen = i2d_X509_EXTENSIONS(s->tlsext_ocsp_exts, NULL);
597
+ if (extlen < 0)
598
+ return NULL;
599
+ }
600
+ else
601
+ extlen = 0;
602
+
603
+ if ((long)(limit - ret - 7 - extlen - idlen) < 0) return NULL;
604
+ s2n(TLSEXT_TYPE_status_request, ret);
605
+ if (extlen + idlen > 0xFFF0)
606
+ return NULL;
607
+ s2n(extlen + idlen + 5, ret);
608
+ *(ret++) = TLSEXT_STATUSTYPE_ocsp;
609
+ s2n(idlen, ret);
610
+ for (i = 0; i < sk_OCSP_RESPID_num(s->tlsext_ocsp_ids); i++)
611
+ {
612
+ /* save position of id len */
613
+ unsigned char *q = ret;
614
+ id = sk_OCSP_RESPID_value(s->tlsext_ocsp_ids, i);
615
+ /* skip over id len */
616
+ ret += 2;
617
+ itmp = i2d_OCSP_RESPID(id, &ret);
618
+ /* write id len */
619
+ s2n(itmp, q);
620
+ }
621
+ s2n(extlen, ret);
622
+ if (extlen > 0)
623
+ i2d_X509_EXTENSIONS(s->tlsext_ocsp_exts, &ret);
624
+ }
625
+
626
+ #ifndef OPENSSL_NO_HEARTBEATS
627
+ /* Add Heartbeat extension */
628
+ s2n(TLSEXT_TYPE_heartbeat,ret);
629
+ s2n(1,ret);
630
+ /* Set mode:
631
+ * 1: peer may send requests
632
+ * 2: peer not allowed to send requests
633
+ */
634
+ if (s->tlsext_heartbeat & SSL_TLSEXT_HB_DONT_RECV_REQUESTS)
635
+ *(ret++) = SSL_TLSEXT_HB_DONT_SEND_REQUESTS;
636
+ else
637
+ *(ret++) = SSL_TLSEXT_HB_ENABLED;
638
+ #endif
639
+
640
+ #ifndef OPENSSL_NO_NEXTPROTONEG
641
+ if (s->ctx->next_proto_select_cb && !s->s3->tmp.finish_md_len)
642
+ {
643
+ /* The client advertises an emtpy extension to indicate its
644
+ * support for Next Protocol Negotiation */
645
+ if (limit - ret - 4 < 0)
646
+ return NULL;
647
+ s2n(TLSEXT_TYPE_next_proto_neg,ret);
648
+ s2n(0,ret);
649
+ }
650
+ #endif
651
+
652
+ if(SSL_get_srtp_profiles(s))
653
+ {
654
+ int el;
655
+
656
+ ssl_add_clienthello_use_srtp_ext(s, 0, &el, 0);
657
+
658
+ if((limit - p - 4 - el) < 0) return NULL;
659
+
660
+ s2n(TLSEXT_TYPE_use_srtp,ret);
661
+ s2n(el,ret);
662
+
663
+ if(ssl_add_clienthello_use_srtp_ext(s, ret, &el, el))
664
+ {
665
+ SSLerr(SSL_F_SSL_ADD_CLIENTHELLO_TLSEXT, ERR_R_INTERNAL_ERROR);
666
+ return NULL;
667
+ }
668
+ ret += el;
669
+ }
670
+
671
+ if ((extdatalen = ret-p-2)== 0)
672
+ return p;
673
+
674
+ s2n(extdatalen,p);
675
+ return ret;
676
+ }
677
+
678
+ unsigned char *ssl_add_serverhello_tlsext(SSL *s, unsigned char *p, unsigned char *limit)
679
+ {
680
+ int extdatalen=0;
681
+ unsigned char *ret = p;
682
+ #ifndef OPENSSL_NO_NEXTPROTONEG
683
+ int next_proto_neg_seen;
684
+ #endif
685
+
686
+ /* don't add extensions for SSLv3, unless doing secure renegotiation */
687
+ if (s->version == SSL3_VERSION && !s->s3->send_connection_binding)
688
+ return p;
689
+
690
+ ret+=2;
691
+ if (ret>=limit) return NULL; /* this really never occurs, but ... */
692
+
693
+ if (!s->hit && s->servername_done == 1 && s->session->tlsext_hostname != NULL)
694
+ {
695
+ if ((long)(limit - ret - 4) < 0) return NULL;
696
+
697
+ s2n(TLSEXT_TYPE_server_name,ret);
698
+ s2n(0,ret);
699
+ }
700
+
701
+ if(s->s3->send_connection_binding)
702
+ {
703
+ int el;
704
+
705
+ if(!ssl_add_serverhello_renegotiate_ext(s, 0, &el, 0))
706
+ {
707
+ SSLerr(SSL_F_SSL_ADD_SERVERHELLO_TLSEXT, ERR_R_INTERNAL_ERROR);
708
+ return NULL;
709
+ }
710
+
711
+ if((limit - p - 4 - el) < 0) return NULL;
712
+
713
+ s2n(TLSEXT_TYPE_renegotiate,ret);
714
+ s2n(el,ret);
715
+
716
+ if(!ssl_add_serverhello_renegotiate_ext(s, ret, &el, el))
717
+ {
718
+ SSLerr(SSL_F_SSL_ADD_SERVERHELLO_TLSEXT, ERR_R_INTERNAL_ERROR);
719
+ return NULL;
720
+ }
721
+
722
+ ret += el;
723
+ }
724
+
725
+ #ifndef OPENSSL_NO_EC
726
+ if (s->tlsext_ecpointformatlist != NULL &&
727
+ s->version != DTLS1_VERSION)
728
+ {
729
+ /* Add TLS extension ECPointFormats to the ServerHello message */
730
+ long lenmax;
731
+
732
+ if ((lenmax = limit - ret - 5) < 0) return NULL;
733
+ if (s->tlsext_ecpointformatlist_length > (unsigned long)lenmax) return NULL;
734
+ if (s->tlsext_ecpointformatlist_length > 255)
735
+ {
736
+ SSLerr(SSL_F_SSL_ADD_SERVERHELLO_TLSEXT, ERR_R_INTERNAL_ERROR);
737
+ return NULL;
738
+ }
739
+
740
+ s2n(TLSEXT_TYPE_ec_point_formats,ret);
741
+ s2n(s->tlsext_ecpointformatlist_length + 1,ret);
742
+ *(ret++) = (unsigned char) s->tlsext_ecpointformatlist_length;
743
+ memcpy(ret, s->tlsext_ecpointformatlist, s->tlsext_ecpointformatlist_length);
744
+ ret+=s->tlsext_ecpointformatlist_length;
745
+
746
+ }
747
+ /* Currently the server should not respond with a SupportedCurves extension */
748
+ #endif /* OPENSSL_NO_EC */
749
+
750
+ if (s->tlsext_ticket_expected
751
+ && !(SSL_get_options(s) & SSL_OP_NO_TICKET))
752
+ {
753
+ if ((long)(limit - ret - 4) < 0) return NULL;
754
+ s2n(TLSEXT_TYPE_session_ticket,ret);
755
+ s2n(0,ret);
756
+ }
757
+
758
+ if (s->tlsext_status_expected)
759
+ {
760
+ if ((long)(limit - ret - 4) < 0) return NULL;
761
+ s2n(TLSEXT_TYPE_status_request,ret);
762
+ s2n(0,ret);
763
+ }
764
+
765
+ #ifdef TLSEXT_TYPE_opaque_prf_input
766
+ if (s->s3->server_opaque_prf_input != NULL &&
767
+ s->version != DTLS1_VERSION)
768
+ {
769
+ size_t sol = s->s3->server_opaque_prf_input_len;
770
+
771
+ if ((long)(limit - ret - 6 - sol) < 0)
772
+ return NULL;
773
+ if (sol > 0xFFFD) /* can't happen */
774
+ return NULL;
775
+
776
+ s2n(TLSEXT_TYPE_opaque_prf_input, ret);
777
+ s2n(sol + 2, ret);
778
+ s2n(sol, ret);
779
+ memcpy(ret, s->s3->server_opaque_prf_input, sol);
780
+ ret += sol;
781
+ }
782
+ #endif
783
+
784
+ if(s->srtp_profile)
785
+ {
786
+ int el;
787
+
788
+ ssl_add_serverhello_use_srtp_ext(s, 0, &el, 0);
789
+
790
+ if((limit - p - 4 - el) < 0) return NULL;
791
+
792
+ s2n(TLSEXT_TYPE_use_srtp,ret);
793
+ s2n(el,ret);
794
+
795
+ if(ssl_add_serverhello_use_srtp_ext(s, ret, &el, el))
796
+ {
797
+ SSLerr(SSL_F_SSL_ADD_SERVERHELLO_TLSEXT, ERR_R_INTERNAL_ERROR);
798
+ return NULL;
799
+ }
800
+ ret+=el;
801
+ }
802
+
803
+ if (((s->s3->tmp.new_cipher->id & 0xFFFF)==0x80 || (s->s3->tmp.new_cipher->id & 0xFFFF)==0x81)
804
+ && (SSL_get_options(s) & SSL_OP_CRYPTOPRO_TLSEXT_BUG))
805
+ { const unsigned char cryptopro_ext[36] = {
806
+ 0xfd, 0xe8, /*65000*/
807
+ 0x00, 0x20, /*32 bytes length*/
808
+ 0x30, 0x1e, 0x30, 0x08, 0x06, 0x06, 0x2a, 0x85,
809
+ 0x03, 0x02, 0x02, 0x09, 0x30, 0x08, 0x06, 0x06,
810
+ 0x2a, 0x85, 0x03, 0x02, 0x02, 0x16, 0x30, 0x08,
811
+ 0x06, 0x06, 0x2a, 0x85, 0x03, 0x02, 0x02, 0x17};
812
+ if (limit-ret<36) return NULL;
813
+ memcpy(ret,cryptopro_ext,36);
814
+ ret+=36;
815
+
816
+ }
817
+
818
+ #ifndef OPENSSL_NO_HEARTBEATS
819
+ /* Add Heartbeat extension if we've received one */
820
+ if (s->tlsext_heartbeat & SSL_TLSEXT_HB_ENABLED)
821
+ {
822
+ s2n(TLSEXT_TYPE_heartbeat,ret);
823
+ s2n(1,ret);
824
+ /* Set mode:
825
+ * 1: peer may send requests
826
+ * 2: peer not allowed to send requests
827
+ */
828
+ if (s->tlsext_heartbeat & SSL_TLSEXT_HB_DONT_RECV_REQUESTS)
829
+ *(ret++) = SSL_TLSEXT_HB_DONT_SEND_REQUESTS;
830
+ else
831
+ *(ret++) = SSL_TLSEXT_HB_ENABLED;
832
+
833
+ }
834
+ #endif
835
+
836
+ #ifndef OPENSSL_NO_NEXTPROTONEG
837
+ next_proto_neg_seen = s->s3->next_proto_neg_seen;
838
+ s->s3->next_proto_neg_seen = 0;
839
+ if (next_proto_neg_seen && s->ctx->next_protos_advertised_cb)
840
+ {
841
+ const unsigned char *npa;
842
+ unsigned int npalen;
843
+ int r;
844
+
845
+ r = s->ctx->next_protos_advertised_cb(s, &npa, &npalen, s->ctx->next_protos_advertised_cb_arg);
846
+ if (r == SSL_TLSEXT_ERR_OK)
847
+ {
848
+ if ((long)(limit - ret - 4 - npalen) < 0) return NULL;
849
+ s2n(TLSEXT_TYPE_next_proto_neg,ret);
850
+ s2n(npalen,ret);
851
+ memcpy(ret, npa, npalen);
852
+ ret += npalen;
853
+ s->s3->next_proto_neg_seen = 1;
854
+ }
855
+ }
856
+ #endif
857
+
858
+ if ((extdatalen = ret-p-2)== 0)
859
+ return p;
860
+
861
+ s2n(extdatalen,p);
862
+ return ret;
863
+ }
864
+
865
+ int ssl_parse_clienthello_tlsext(SSL *s, unsigned char **p, unsigned char *d, int n, int *al)
866
+ {
867
+ unsigned short type;
868
+ unsigned short size;
869
+ unsigned short len;
870
+ unsigned char *data = *p;
871
+ int renegotiate_seen = 0;
872
+ int sigalg_seen = 0;
873
+
874
+ s->servername_done = 0;
875
+ s->tlsext_status_type = -1;
876
+ #ifndef OPENSSL_NO_NEXTPROTONEG
877
+ s->s3->next_proto_neg_seen = 0;
878
+ #endif
879
+
880
+ #ifndef OPENSSL_NO_HEARTBEATS
881
+ s->tlsext_heartbeat &= ~(SSL_TLSEXT_HB_ENABLED |
882
+ SSL_TLSEXT_HB_DONT_SEND_REQUESTS);
883
+ #endif
884
+
885
+ if (data >= (d+n-2))
886
+ goto ri_check;
887
+ n2s(data,len);
888
+
889
+ if (data > (d+n-len))
890
+ goto ri_check;
891
+
892
+ while (data <= (d+n-4))
893
+ {
894
+ n2s(data,type);
895
+ n2s(data,size);
896
+
897
+ if (data+size > (d+n))
898
+ goto ri_check;
899
+ #if 0
900
+ fprintf(stderr,"Received extension type %d size %d\n",type,size);
901
+ #endif
902
+ if (s->tlsext_debug_cb)
903
+ s->tlsext_debug_cb(s, 0, type, data, size,
904
+ s->tlsext_debug_arg);
905
+ /* The servername extension is treated as follows:
906
+
907
+ - Only the hostname type is supported with a maximum length of 255.
908
+ - The servername is rejected if too long or if it contains zeros,
909
+ in which case an fatal alert is generated.
910
+ - The servername field is maintained together with the session cache.
911
+ - When a session is resumed, the servername call back invoked in order
912
+ to allow the application to position itself to the right context.
913
+ - The servername is acknowledged if it is new for a session or when
914
+ it is identical to a previously used for the same session.
915
+ Applications can control the behaviour. They can at any time
916
+ set a 'desirable' servername for a new SSL object. This can be the
917
+ case for example with HTTPS when a Host: header field is received and
918
+ a renegotiation is requested. In this case, a possible servername
919
+ presented in the new client hello is only acknowledged if it matches
920
+ the value of the Host: field.
921
+ - Applications must use SSL_OP_NO_SESSION_RESUMPTION_ON_RENEGOTIATION
922
+ if they provide for changing an explicit servername context for the session,
923
+ i.e. when the session has been established with a servername extension.
924
+ - On session reconnect, the servername extension may be absent.
925
+
926
+ */
927
+
928
+ if (type == TLSEXT_TYPE_server_name)
929
+ {
930
+ unsigned char *sdata;
931
+ int servname_type;
932
+ int dsize;
933
+
934
+ if (size < 2)
935
+ {
936
+ *al = SSL_AD_DECODE_ERROR;
937
+ return 0;
938
+ }
939
+ n2s(data,dsize);
940
+ size -= 2;
941
+ if (dsize > size )
942
+ {
943
+ *al = SSL_AD_DECODE_ERROR;
944
+ return 0;
945
+ }
946
+
947
+ sdata = data;
948
+ while (dsize > 3)
949
+ {
950
+ servname_type = *(sdata++);
951
+ n2s(sdata,len);
952
+ dsize -= 3;
953
+
954
+ if (len > dsize)
955
+ {
956
+ *al = SSL_AD_DECODE_ERROR;
957
+ return 0;
958
+ }
959
+ if (s->servername_done == 0)
960
+ switch (servname_type)
961
+ {
962
+ case TLSEXT_NAMETYPE_host_name:
963
+ if (!s->hit)
964
+ {
965
+ if(s->session->tlsext_hostname)
966
+ {
967
+ *al = SSL_AD_DECODE_ERROR;
968
+ return 0;
969
+ }
970
+ if (len > TLSEXT_MAXLEN_host_name)
971
+ {
972
+ *al = TLS1_AD_UNRECOGNIZED_NAME;
973
+ return 0;
974
+ }
975
+ if ((s->session->tlsext_hostname = OPENSSL_malloc(len+1)) == NULL)
976
+ {
977
+ *al = TLS1_AD_INTERNAL_ERROR;
978
+ return 0;
979
+ }
980
+ memcpy(s->session->tlsext_hostname, sdata, len);
981
+ s->session->tlsext_hostname[len]='\0';
982
+ if (strlen(s->session->tlsext_hostname) != len) {
983
+ OPENSSL_free(s->session->tlsext_hostname);
984
+ s->session->tlsext_hostname = NULL;
985
+ *al = TLS1_AD_UNRECOGNIZED_NAME;
986
+ return 0;
987
+ }
988
+ s->servername_done = 1;
989
+
990
+ }
991
+ else
992
+ s->servername_done = s->session->tlsext_hostname
993
+ && strlen(s->session->tlsext_hostname) == len
994
+ && strncmp(s->session->tlsext_hostname, (char *)sdata, len) == 0;
995
+
996
+ break;
997
+
998
+ default:
999
+ break;
1000
+ }
1001
+
1002
+ dsize -= len;
1003
+ }
1004
+ if (dsize != 0)
1005
+ {
1006
+ *al = SSL_AD_DECODE_ERROR;
1007
+ return 0;
1008
+ }
1009
+
1010
+ }
1011
+ #ifndef OPENSSL_NO_SRP
1012
+ else if (type == TLSEXT_TYPE_srp)
1013
+ {
1014
+ if (size <= 0 || ((len = data[0])) != (size -1))
1015
+ {
1016
+ *al = SSL_AD_DECODE_ERROR;
1017
+ return 0;
1018
+ }
1019
+ if (s->srp_ctx.login != NULL)
1020
+ {
1021
+ *al = SSL_AD_DECODE_ERROR;
1022
+ return 0;
1023
+ }
1024
+ if ((s->srp_ctx.login = OPENSSL_malloc(len+1)) == NULL)
1025
+ return -1;
1026
+ memcpy(s->srp_ctx.login, &data[1], len);
1027
+ s->srp_ctx.login[len]='\0';
1028
+
1029
+ if (strlen(s->srp_ctx.login) != len)
1030
+ {
1031
+ *al = SSL_AD_DECODE_ERROR;
1032
+ return 0;
1033
+ }
1034
+ }
1035
+ #endif
1036
+
1037
+ #ifndef OPENSSL_NO_EC
1038
+ else if (type == TLSEXT_TYPE_ec_point_formats &&
1039
+ s->version != DTLS1_VERSION)
1040
+ {
1041
+ unsigned char *sdata = data;
1042
+ int ecpointformatlist_length = *(sdata++);
1043
+
1044
+ if (ecpointformatlist_length != size - 1)
1045
+ {
1046
+ *al = TLS1_AD_DECODE_ERROR;
1047
+ return 0;
1048
+ }
1049
+ if (!s->hit)
1050
+ {
1051
+ if(s->session->tlsext_ecpointformatlist)
1052
+ {
1053
+ OPENSSL_free(s->session->tlsext_ecpointformatlist);
1054
+ s->session->tlsext_ecpointformatlist = NULL;
1055
+ }
1056
+ s->session->tlsext_ecpointformatlist_length = 0;
1057
+ if ((s->session->tlsext_ecpointformatlist = OPENSSL_malloc(ecpointformatlist_length)) == NULL)
1058
+ {
1059
+ *al = TLS1_AD_INTERNAL_ERROR;
1060
+ return 0;
1061
+ }
1062
+ s->session->tlsext_ecpointformatlist_length = ecpointformatlist_length;
1063
+ memcpy(s->session->tlsext_ecpointformatlist, sdata, ecpointformatlist_length);
1064
+ }
1065
+ #if 0
1066
+ fprintf(stderr,"ssl_parse_clienthello_tlsext s->session->tlsext_ecpointformatlist (length=%i) ", s->session->tlsext_ecpointformatlist_length);
1067
+ sdata = s->session->tlsext_ecpointformatlist;
1068
+ for (i = 0; i < s->session->tlsext_ecpointformatlist_length; i++)
1069
+ fprintf(stderr,"%i ",*(sdata++));
1070
+ fprintf(stderr,"\n");
1071
+ #endif
1072
+ }
1073
+ else if (type == TLSEXT_TYPE_elliptic_curves &&
1074
+ s->version != DTLS1_VERSION)
1075
+ {
1076
+ unsigned char *sdata = data;
1077
+ int ellipticcurvelist_length = (*(sdata++) << 8);
1078
+ ellipticcurvelist_length += (*(sdata++));
1079
+
1080
+ if (ellipticcurvelist_length != size - 2)
1081
+ {
1082
+ *al = TLS1_AD_DECODE_ERROR;
1083
+ return 0;
1084
+ }
1085
+ if (!s->hit)
1086
+ {
1087
+ if(s->session->tlsext_ellipticcurvelist)
1088
+ {
1089
+ *al = TLS1_AD_DECODE_ERROR;
1090
+ return 0;
1091
+ }
1092
+ s->session->tlsext_ellipticcurvelist_length = 0;
1093
+ if ((s->session->tlsext_ellipticcurvelist = OPENSSL_malloc(ellipticcurvelist_length)) == NULL)
1094
+ {
1095
+ *al = TLS1_AD_INTERNAL_ERROR;
1096
+ return 0;
1097
+ }
1098
+ s->session->tlsext_ellipticcurvelist_length = ellipticcurvelist_length;
1099
+ memcpy(s->session->tlsext_ellipticcurvelist, sdata, ellipticcurvelist_length);
1100
+ }
1101
+ #if 0
1102
+ fprintf(stderr,"ssl_parse_clienthello_tlsext s->session->tlsext_ellipticcurvelist (length=%i) ", s->session->tlsext_ellipticcurvelist_length);
1103
+ sdata = s->session->tlsext_ellipticcurvelist;
1104
+ for (i = 0; i < s->session->tlsext_ellipticcurvelist_length; i++)
1105
+ fprintf(stderr,"%i ",*(sdata++));
1106
+ fprintf(stderr,"\n");
1107
+ #endif
1108
+ }
1109
+ #endif /* OPENSSL_NO_EC */
1110
+ #ifdef TLSEXT_TYPE_opaque_prf_input
1111
+ else if (type == TLSEXT_TYPE_opaque_prf_input &&
1112
+ s->version != DTLS1_VERSION)
1113
+ {
1114
+ unsigned char *sdata = data;
1115
+
1116
+ if (size < 2)
1117
+ {
1118
+ *al = SSL_AD_DECODE_ERROR;
1119
+ return 0;
1120
+ }
1121
+ n2s(sdata, s->s3->client_opaque_prf_input_len);
1122
+ if (s->s3->client_opaque_prf_input_len != size - 2)
1123
+ {
1124
+ *al = SSL_AD_DECODE_ERROR;
1125
+ return 0;
1126
+ }
1127
+
1128
+ if (s->s3->client_opaque_prf_input != NULL) /* shouldn't really happen */
1129
+ OPENSSL_free(s->s3->client_opaque_prf_input);
1130
+ if (s->s3->client_opaque_prf_input_len == 0)
1131
+ s->s3->client_opaque_prf_input = OPENSSL_malloc(1); /* dummy byte just to get non-NULL */
1132
+ else
1133
+ s->s3->client_opaque_prf_input = BUF_memdup(sdata, s->s3->client_opaque_prf_input_len);
1134
+ if (s->s3->client_opaque_prf_input == NULL)
1135
+ {
1136
+ *al = TLS1_AD_INTERNAL_ERROR;
1137
+ return 0;
1138
+ }
1139
+ }
1140
+ #endif
1141
+ else if (type == TLSEXT_TYPE_session_ticket)
1142
+ {
1143
+ if (s->tls_session_ticket_ext_cb &&
1144
+ !s->tls_session_ticket_ext_cb(s, data, size, s->tls_session_ticket_ext_cb_arg))
1145
+ {
1146
+ *al = TLS1_AD_INTERNAL_ERROR;
1147
+ return 0;
1148
+ }
1149
+ }
1150
+ else if (type == TLSEXT_TYPE_renegotiate)
1151
+ {
1152
+ if(!ssl_parse_clienthello_renegotiate_ext(s, data, size, al))
1153
+ return 0;
1154
+ renegotiate_seen = 1;
1155
+ }
1156
+ else if (type == TLSEXT_TYPE_signature_algorithms)
1157
+ {
1158
+ int dsize;
1159
+ if (sigalg_seen || size < 2)
1160
+ {
1161
+ *al = SSL_AD_DECODE_ERROR;
1162
+ return 0;
1163
+ }
1164
+ sigalg_seen = 1;
1165
+ n2s(data,dsize);
1166
+ size -= 2;
1167
+ if (dsize != size || dsize & 1)
1168
+ {
1169
+ *al = SSL_AD_DECODE_ERROR;
1170
+ return 0;
1171
+ }
1172
+ if (!tls1_process_sigalgs(s, data, dsize))
1173
+ {
1174
+ *al = SSL_AD_DECODE_ERROR;
1175
+ return 0;
1176
+ }
1177
+ }
1178
+ else if (type == TLSEXT_TYPE_status_request &&
1179
+ s->version != DTLS1_VERSION && s->ctx->tlsext_status_cb)
1180
+ {
1181
+
1182
+ if (size < 5)
1183
+ {
1184
+ *al = SSL_AD_DECODE_ERROR;
1185
+ return 0;
1186
+ }
1187
+
1188
+ s->tlsext_status_type = *data++;
1189
+ size--;
1190
+ if (s->tlsext_status_type == TLSEXT_STATUSTYPE_ocsp)
1191
+ {
1192
+ const unsigned char *sdata;
1193
+ int dsize;
1194
+ /* Read in responder_id_list */
1195
+ n2s(data,dsize);
1196
+ size -= 2;
1197
+ if (dsize > size )
1198
+ {
1199
+ *al = SSL_AD_DECODE_ERROR;
1200
+ return 0;
1201
+ }
1202
+ while (dsize > 0)
1203
+ {
1204
+ OCSP_RESPID *id;
1205
+ int idsize;
1206
+ if (dsize < 4)
1207
+ {
1208
+ *al = SSL_AD_DECODE_ERROR;
1209
+ return 0;
1210
+ }
1211
+ n2s(data, idsize);
1212
+ dsize -= 2 + idsize;
1213
+ size -= 2 + idsize;
1214
+ if (dsize < 0)
1215
+ {
1216
+ *al = SSL_AD_DECODE_ERROR;
1217
+ return 0;
1218
+ }
1219
+ sdata = data;
1220
+ data += idsize;
1221
+ id = d2i_OCSP_RESPID(NULL,
1222
+ &sdata, idsize);
1223
+ if (!id)
1224
+ {
1225
+ *al = SSL_AD_DECODE_ERROR;
1226
+ return 0;
1227
+ }
1228
+ if (data != sdata)
1229
+ {
1230
+ OCSP_RESPID_free(id);
1231
+ *al = SSL_AD_DECODE_ERROR;
1232
+ return 0;
1233
+ }
1234
+ if (!s->tlsext_ocsp_ids
1235
+ && !(s->tlsext_ocsp_ids =
1236
+ sk_OCSP_RESPID_new_null()))
1237
+ {
1238
+ OCSP_RESPID_free(id);
1239
+ *al = SSL_AD_INTERNAL_ERROR;
1240
+ return 0;
1241
+ }
1242
+ if (!sk_OCSP_RESPID_push(
1243
+ s->tlsext_ocsp_ids, id))
1244
+ {
1245
+ OCSP_RESPID_free(id);
1246
+ *al = SSL_AD_INTERNAL_ERROR;
1247
+ return 0;
1248
+ }
1249
+ }
1250
+
1251
+ /* Read in request_extensions */
1252
+ if (size < 2)
1253
+ {
1254
+ *al = SSL_AD_DECODE_ERROR;
1255
+ return 0;
1256
+ }
1257
+ n2s(data,dsize);
1258
+ size -= 2;
1259
+ if (dsize != size)
1260
+ {
1261
+ *al = SSL_AD_DECODE_ERROR;
1262
+ return 0;
1263
+ }
1264
+ sdata = data;
1265
+ if (dsize > 0)
1266
+ {
1267
+ if (s->tlsext_ocsp_exts)
1268
+ {
1269
+ sk_X509_EXTENSION_pop_free(s->tlsext_ocsp_exts,
1270
+ X509_EXTENSION_free);
1271
+ }
1272
+
1273
+ s->tlsext_ocsp_exts =
1274
+ d2i_X509_EXTENSIONS(NULL,
1275
+ &sdata, dsize);
1276
+ if (!s->tlsext_ocsp_exts
1277
+ || (data + dsize != sdata))
1278
+ {
1279
+ *al = SSL_AD_DECODE_ERROR;
1280
+ return 0;
1281
+ }
1282
+ }
1283
+ }
1284
+ /* We don't know what to do with any other type
1285
+ * so ignore it.
1286
+ */
1287
+ else
1288
+ s->tlsext_status_type = -1;
1289
+ }
1290
+ #ifndef OPENSSL_NO_HEARTBEATS
1291
+ else if (type == TLSEXT_TYPE_heartbeat)
1292
+ {
1293
+ switch(data[0])
1294
+ {
1295
+ case 0x01: /* Client allows us to send HB requests */
1296
+ s->tlsext_heartbeat |= SSL_TLSEXT_HB_ENABLED;
1297
+ break;
1298
+ case 0x02: /* Client doesn't accept HB requests */
1299
+ s->tlsext_heartbeat |= SSL_TLSEXT_HB_ENABLED;
1300
+ s->tlsext_heartbeat |= SSL_TLSEXT_HB_DONT_SEND_REQUESTS;
1301
+ break;
1302
+ default: *al = SSL_AD_ILLEGAL_PARAMETER;
1303
+ return 0;
1304
+ }
1305
+ }
1306
+ #endif
1307
+ #ifndef OPENSSL_NO_NEXTPROTONEG
1308
+ else if (type == TLSEXT_TYPE_next_proto_neg &&
1309
+ s->s3->tmp.finish_md_len == 0)
1310
+ {
1311
+ /* We shouldn't accept this extension on a
1312
+ * renegotiation.
1313
+ *
1314
+ * s->new_session will be set on renegotiation, but we
1315
+ * probably shouldn't rely that it couldn't be set on
1316
+ * the initial renegotation too in certain cases (when
1317
+ * there's some other reason to disallow resuming an
1318
+ * earlier session -- the current code won't be doing
1319
+ * anything like that, but this might change).
1320
+
1321
+ * A valid sign that there's been a previous handshake
1322
+ * in this connection is if s->s3->tmp.finish_md_len >
1323
+ * 0. (We are talking about a check that will happen
1324
+ * in the Hello protocol round, well before a new
1325
+ * Finished message could have been computed.) */
1326
+ s->s3->next_proto_neg_seen = 1;
1327
+ }
1328
+ #endif
1329
+
1330
+ /* session ticket processed earlier */
1331
+ else if (type == TLSEXT_TYPE_use_srtp)
1332
+ {
1333
+ if(ssl_parse_clienthello_use_srtp_ext(s, data, size,
1334
+ al))
1335
+ return 0;
1336
+ }
1337
+
1338
+ data+=size;
1339
+ }
1340
+
1341
+ *p = data;
1342
+
1343
+ ri_check:
1344
+
1345
+ /* Need RI if renegotiating */
1346
+
1347
+ if (!renegotiate_seen && s->renegotiate &&
1348
+ !(s->options & SSL_OP_ALLOW_UNSAFE_LEGACY_RENEGOTIATION))
1349
+ {
1350
+ *al = SSL_AD_HANDSHAKE_FAILURE;
1351
+ SSLerr(SSL_F_SSL_PARSE_CLIENTHELLO_TLSEXT,
1352
+ SSL_R_UNSAFE_LEGACY_RENEGOTIATION_DISABLED);
1353
+ return 0;
1354
+ }
1355
+
1356
+ return 1;
1357
+ }
1358
+
1359
+ #ifndef OPENSSL_NO_NEXTPROTONEG
1360
+ /* ssl_next_proto_validate validates a Next Protocol Negotiation block. No
1361
+ * elements of zero length are allowed and the set of elements must exactly fill
1362
+ * the length of the block. */
1363
+ static char ssl_next_proto_validate(unsigned char *d, unsigned len)
1364
+ {
1365
+ unsigned int off = 0;
1366
+
1367
+ while (off < len)
1368
+ {
1369
+ if (d[off] == 0)
1370
+ return 0;
1371
+ off += d[off];
1372
+ off++;
1373
+ }
1374
+
1375
+ return off == len;
1376
+ }
1377
+ #endif
1378
+
1379
+ int ssl_parse_serverhello_tlsext(SSL *s, unsigned char **p, unsigned char *d, int n, int *al)
1380
+ {
1381
+ unsigned short length;
1382
+ unsigned short type;
1383
+ unsigned short size;
1384
+ unsigned char *data = *p;
1385
+ int tlsext_servername = 0;
1386
+ int renegotiate_seen = 0;
1387
+
1388
+ #ifndef OPENSSL_NO_NEXTPROTONEG
1389
+ s->s3->next_proto_neg_seen = 0;
1390
+ #endif
1391
+
1392
+ #ifndef OPENSSL_NO_HEARTBEATS
1393
+ s->tlsext_heartbeat &= ~(SSL_TLSEXT_HB_ENABLED |
1394
+ SSL_TLSEXT_HB_DONT_SEND_REQUESTS);
1395
+ #endif
1396
+
1397
+ if (data >= (d+n-2))
1398
+ goto ri_check;
1399
+
1400
+ n2s(data,length);
1401
+ if (data+length != d+n)
1402
+ {
1403
+ *al = SSL_AD_DECODE_ERROR;
1404
+ return 0;
1405
+ }
1406
+
1407
+ while(data <= (d+n-4))
1408
+ {
1409
+ n2s(data,type);
1410
+ n2s(data,size);
1411
+
1412
+ if (data+size > (d+n))
1413
+ goto ri_check;
1414
+
1415
+ if (s->tlsext_debug_cb)
1416
+ s->tlsext_debug_cb(s, 1, type, data, size,
1417
+ s->tlsext_debug_arg);
1418
+
1419
+ if (type == TLSEXT_TYPE_server_name)
1420
+ {
1421
+ if (s->tlsext_hostname == NULL || size > 0)
1422
+ {
1423
+ *al = TLS1_AD_UNRECOGNIZED_NAME;
1424
+ return 0;
1425
+ }
1426
+ tlsext_servername = 1;
1427
+ }
1428
+
1429
+ #ifndef OPENSSL_NO_EC
1430
+ else if (type == TLSEXT_TYPE_ec_point_formats &&
1431
+ s->version != DTLS1_VERSION)
1432
+ {
1433
+ unsigned char *sdata = data;
1434
+ int ecpointformatlist_length = *(sdata++);
1435
+
1436
+ if (ecpointformatlist_length != size - 1)
1437
+ {
1438
+ *al = TLS1_AD_DECODE_ERROR;
1439
+ return 0;
1440
+ }
1441
+ s->session->tlsext_ecpointformatlist_length = 0;
1442
+ if (s->session->tlsext_ecpointformatlist != NULL) OPENSSL_free(s->session->tlsext_ecpointformatlist);
1443
+ if ((s->session->tlsext_ecpointformatlist = OPENSSL_malloc(ecpointformatlist_length)) == NULL)
1444
+ {
1445
+ *al = TLS1_AD_INTERNAL_ERROR;
1446
+ return 0;
1447
+ }
1448
+ s->session->tlsext_ecpointformatlist_length = ecpointformatlist_length;
1449
+ memcpy(s->session->tlsext_ecpointformatlist, sdata, ecpointformatlist_length);
1450
+ #if 0
1451
+ fprintf(stderr,"ssl_parse_serverhello_tlsext s->session->tlsext_ecpointformatlist ");
1452
+ sdata = s->session->tlsext_ecpointformatlist;
1453
+ for (i = 0; i < s->session->tlsext_ecpointformatlist_length; i++)
1454
+ fprintf(stderr,"%i ",*(sdata++));
1455
+ fprintf(stderr,"\n");
1456
+ #endif
1457
+ }
1458
+ #endif /* OPENSSL_NO_EC */
1459
+
1460
+ else if (type == TLSEXT_TYPE_session_ticket)
1461
+ {
1462
+ if (s->tls_session_ticket_ext_cb &&
1463
+ !s->tls_session_ticket_ext_cb(s, data, size, s->tls_session_ticket_ext_cb_arg))
1464
+ {
1465
+ *al = TLS1_AD_INTERNAL_ERROR;
1466
+ return 0;
1467
+ }
1468
+ if ((SSL_get_options(s) & SSL_OP_NO_TICKET)
1469
+ || (size > 0))
1470
+ {
1471
+ *al = TLS1_AD_UNSUPPORTED_EXTENSION;
1472
+ return 0;
1473
+ }
1474
+ s->tlsext_ticket_expected = 1;
1475
+ }
1476
+ #ifdef TLSEXT_TYPE_opaque_prf_input
1477
+ else if (type == TLSEXT_TYPE_opaque_prf_input &&
1478
+ s->version != DTLS1_VERSION)
1479
+ {
1480
+ unsigned char *sdata = data;
1481
+
1482
+ if (size < 2)
1483
+ {
1484
+ *al = SSL_AD_DECODE_ERROR;
1485
+ return 0;
1486
+ }
1487
+ n2s(sdata, s->s3->server_opaque_prf_input_len);
1488
+ if (s->s3->server_opaque_prf_input_len != size - 2)
1489
+ {
1490
+ *al = SSL_AD_DECODE_ERROR;
1491
+ return 0;
1492
+ }
1493
+
1494
+ if (s->s3->server_opaque_prf_input != NULL) /* shouldn't really happen */
1495
+ OPENSSL_free(s->s3->server_opaque_prf_input);
1496
+ if (s->s3->server_opaque_prf_input_len == 0)
1497
+ s->s3->server_opaque_prf_input = OPENSSL_malloc(1); /* dummy byte just to get non-NULL */
1498
+ else
1499
+ s->s3->server_opaque_prf_input = BUF_memdup(sdata, s->s3->server_opaque_prf_input_len);
1500
+
1501
+ if (s->s3->server_opaque_prf_input == NULL)
1502
+ {
1503
+ *al = TLS1_AD_INTERNAL_ERROR;
1504
+ return 0;
1505
+ }
1506
+ }
1507
+ #endif
1508
+ else if (type == TLSEXT_TYPE_status_request &&
1509
+ s->version != DTLS1_VERSION)
1510
+ {
1511
+ /* MUST be empty and only sent if we've requested
1512
+ * a status request message.
1513
+ */
1514
+ if ((s->tlsext_status_type == -1) || (size > 0))
1515
+ {
1516
+ *al = TLS1_AD_UNSUPPORTED_EXTENSION;
1517
+ return 0;
1518
+ }
1519
+ /* Set flag to expect CertificateStatus message */
1520
+ s->tlsext_status_expected = 1;
1521
+ }
1522
+ #ifndef OPENSSL_NO_NEXTPROTONEG
1523
+ else if (type == TLSEXT_TYPE_next_proto_neg &&
1524
+ s->s3->tmp.finish_md_len == 0)
1525
+ {
1526
+ unsigned char *selected;
1527
+ unsigned char selected_len;
1528
+
1529
+ /* We must have requested it. */
1530
+ if ((s->ctx->next_proto_select_cb == NULL))
1531
+ {
1532
+ *al = TLS1_AD_UNSUPPORTED_EXTENSION;
1533
+ return 0;
1534
+ }
1535
+ /* The data must be valid */
1536
+ if (!ssl_next_proto_validate(data, size))
1537
+ {
1538
+ *al = TLS1_AD_DECODE_ERROR;
1539
+ return 0;
1540
+ }
1541
+ if (s->ctx->next_proto_select_cb(s, &selected, &selected_len, data, size, s->ctx->next_proto_select_cb_arg) != SSL_TLSEXT_ERR_OK)
1542
+ {
1543
+ *al = TLS1_AD_INTERNAL_ERROR;
1544
+ return 0;
1545
+ }
1546
+ s->next_proto_negotiated = OPENSSL_malloc(selected_len);
1547
+ if (!s->next_proto_negotiated)
1548
+ {
1549
+ *al = TLS1_AD_INTERNAL_ERROR;
1550
+ return 0;
1551
+ }
1552
+ memcpy(s->next_proto_negotiated, selected, selected_len);
1553
+ s->next_proto_negotiated_len = selected_len;
1554
+ s->s3->next_proto_neg_seen = 1;
1555
+ }
1556
+ #endif
1557
+ else if (type == TLSEXT_TYPE_renegotiate)
1558
+ {
1559
+ if(!ssl_parse_serverhello_renegotiate_ext(s, data, size, al))
1560
+ return 0;
1561
+ renegotiate_seen = 1;
1562
+ }
1563
+ #ifndef OPENSSL_NO_HEARTBEATS
1564
+ else if (type == TLSEXT_TYPE_heartbeat)
1565
+ {
1566
+ switch(data[0])
1567
+ {
1568
+ case 0x01: /* Server allows us to send HB requests */
1569
+ s->tlsext_heartbeat |= SSL_TLSEXT_HB_ENABLED;
1570
+ break;
1571
+ case 0x02: /* Server doesn't accept HB requests */
1572
+ s->tlsext_heartbeat |= SSL_TLSEXT_HB_ENABLED;
1573
+ s->tlsext_heartbeat |= SSL_TLSEXT_HB_DONT_SEND_REQUESTS;
1574
+ break;
1575
+ default: *al = SSL_AD_ILLEGAL_PARAMETER;
1576
+ return 0;
1577
+ }
1578
+ }
1579
+ #endif
1580
+ else if (type == TLSEXT_TYPE_use_srtp)
1581
+ {
1582
+ if(ssl_parse_serverhello_use_srtp_ext(s, data, size,
1583
+ al))
1584
+ return 0;
1585
+ }
1586
+
1587
+ data+=size;
1588
+ }
1589
+
1590
+ if (data != d+n)
1591
+ {
1592
+ *al = SSL_AD_DECODE_ERROR;
1593
+ return 0;
1594
+ }
1595
+
1596
+ if (!s->hit && tlsext_servername == 1)
1597
+ {
1598
+ if (s->tlsext_hostname)
1599
+ {
1600
+ if (s->session->tlsext_hostname == NULL)
1601
+ {
1602
+ s->session->tlsext_hostname = BUF_strdup(s->tlsext_hostname);
1603
+ if (!s->session->tlsext_hostname)
1604
+ {
1605
+ *al = SSL_AD_UNRECOGNIZED_NAME;
1606
+ return 0;
1607
+ }
1608
+ }
1609
+ else
1610
+ {
1611
+ *al = SSL_AD_DECODE_ERROR;
1612
+ return 0;
1613
+ }
1614
+ }
1615
+ }
1616
+
1617
+ *p = data;
1618
+
1619
+ ri_check:
1620
+
1621
+ /* Determine if we need to see RI. Strictly speaking if we want to
1622
+ * avoid an attack we should *always* see RI even on initial server
1623
+ * hello because the client doesn't see any renegotiation during an
1624
+ * attack. However this would mean we could not connect to any server
1625
+ * which doesn't support RI so for the immediate future tolerate RI
1626
+ * absence on initial connect only.
1627
+ */
1628
+ if (!renegotiate_seen
1629
+ && !(s->options & SSL_OP_LEGACY_SERVER_CONNECT)
1630
+ && !(s->options & SSL_OP_ALLOW_UNSAFE_LEGACY_RENEGOTIATION))
1631
+ {
1632
+ *al = SSL_AD_HANDSHAKE_FAILURE;
1633
+ SSLerr(SSL_F_SSL_PARSE_SERVERHELLO_TLSEXT,
1634
+ SSL_R_UNSAFE_LEGACY_RENEGOTIATION_DISABLED);
1635
+ return 0;
1636
+ }
1637
+
1638
+ return 1;
1639
+ }
1640
+
1641
+
1642
+ int ssl_prepare_clienthello_tlsext(SSL *s)
1643
+ {
1644
+ #ifndef OPENSSL_NO_EC
1645
+ /* If we are client and using an elliptic curve cryptography cipher suite, send the point formats
1646
+ * and elliptic curves we support.
1647
+ */
1648
+ int using_ecc = 0;
1649
+ int i;
1650
+ unsigned char *j;
1651
+ unsigned long alg_k, alg_a;
1652
+ STACK_OF(SSL_CIPHER) *cipher_stack = SSL_get_ciphers(s);
1653
+
1654
+ for (i = 0; i < sk_SSL_CIPHER_num(cipher_stack); i++)
1655
+ {
1656
+ SSL_CIPHER *c = sk_SSL_CIPHER_value(cipher_stack, i);
1657
+
1658
+ alg_k = c->algorithm_mkey;
1659
+ alg_a = c->algorithm_auth;
1660
+ if ((alg_k & (SSL_kEECDH|SSL_kECDHr|SSL_kECDHe) || (alg_a & SSL_aECDSA)))
1661
+ {
1662
+ using_ecc = 1;
1663
+ break;
1664
+ }
1665
+ }
1666
+ using_ecc = using_ecc && (s->version >= TLS1_VERSION);
1667
+ if (using_ecc)
1668
+ {
1669
+ if (s->tlsext_ecpointformatlist != NULL) OPENSSL_free(s->tlsext_ecpointformatlist);
1670
+ if ((s->tlsext_ecpointformatlist = OPENSSL_malloc(3)) == NULL)
1671
+ {
1672
+ SSLerr(SSL_F_SSL_PREPARE_CLIENTHELLO_TLSEXT,ERR_R_MALLOC_FAILURE);
1673
+ return -1;
1674
+ }
1675
+ s->tlsext_ecpointformatlist_length = 3;
1676
+ s->tlsext_ecpointformatlist[0] = TLSEXT_ECPOINTFORMAT_uncompressed;
1677
+ s->tlsext_ecpointformatlist[1] = TLSEXT_ECPOINTFORMAT_ansiX962_compressed_prime;
1678
+ s->tlsext_ecpointformatlist[2] = TLSEXT_ECPOINTFORMAT_ansiX962_compressed_char2;
1679
+
1680
+ /* we support all named elliptic curves in draft-ietf-tls-ecc-12 */
1681
+ if (s->tlsext_ellipticcurvelist != NULL) OPENSSL_free(s->tlsext_ellipticcurvelist);
1682
+ s->tlsext_ellipticcurvelist_length = sizeof(pref_list)/sizeof(pref_list[0]) * 2;
1683
+ if ((s->tlsext_ellipticcurvelist = OPENSSL_malloc(s->tlsext_ellipticcurvelist_length)) == NULL)
1684
+ {
1685
+ s->tlsext_ellipticcurvelist_length = 0;
1686
+ SSLerr(SSL_F_SSL_PREPARE_CLIENTHELLO_TLSEXT,ERR_R_MALLOC_FAILURE);
1687
+ return -1;
1688
+ }
1689
+ for (i = 0, j = s->tlsext_ellipticcurvelist; (unsigned int)i <
1690
+ sizeof(pref_list)/sizeof(pref_list[0]); i++)
1691
+ {
1692
+ int id = tls1_ec_nid2curve_id(pref_list[i]);
1693
+ s2n(id,j);
1694
+ }
1695
+ }
1696
+ #endif /* OPENSSL_NO_EC */
1697
+
1698
+ #ifdef TLSEXT_TYPE_opaque_prf_input
1699
+ {
1700
+ int r = 1;
1701
+
1702
+ if (s->ctx->tlsext_opaque_prf_input_callback != 0)
1703
+ {
1704
+ r = s->ctx->tlsext_opaque_prf_input_callback(s, NULL, 0, s->ctx->tlsext_opaque_prf_input_callback_arg);
1705
+ if (!r)
1706
+ return -1;
1707
+ }
1708
+
1709
+ if (s->tlsext_opaque_prf_input != NULL)
1710
+ {
1711
+ if (s->s3->client_opaque_prf_input != NULL) /* shouldn't really happen */
1712
+ OPENSSL_free(s->s3->client_opaque_prf_input);
1713
+
1714
+ if (s->tlsext_opaque_prf_input_len == 0)
1715
+ s->s3->client_opaque_prf_input = OPENSSL_malloc(1); /* dummy byte just to get non-NULL */
1716
+ else
1717
+ s->s3->client_opaque_prf_input = BUF_memdup(s->tlsext_opaque_prf_input, s->tlsext_opaque_prf_input_len);
1718
+ if (s->s3->client_opaque_prf_input == NULL)
1719
+ {
1720
+ SSLerr(SSL_F_SSL_PREPARE_CLIENTHELLO_TLSEXT,ERR_R_MALLOC_FAILURE);
1721
+ return -1;
1722
+ }
1723
+ s->s3->client_opaque_prf_input_len = s->tlsext_opaque_prf_input_len;
1724
+ }
1725
+
1726
+ if (r == 2)
1727
+ /* at callback's request, insist on receiving an appropriate server opaque PRF input */
1728
+ s->s3->server_opaque_prf_input_len = s->tlsext_opaque_prf_input_len;
1729
+ }
1730
+ #endif
1731
+
1732
+ return 1;
1733
+ }
1734
+
1735
+ int ssl_prepare_serverhello_tlsext(SSL *s)
1736
+ {
1737
+ #ifndef OPENSSL_NO_EC
1738
+ /* If we are server and using an ECC cipher suite, send the point formats we support
1739
+ * if the client sent us an ECPointsFormat extension. Note that the server is not
1740
+ * supposed to send an EllipticCurves extension.
1741
+ */
1742
+
1743
+ unsigned long alg_k = s->s3->tmp.new_cipher->algorithm_mkey;
1744
+ unsigned long alg_a = s->s3->tmp.new_cipher->algorithm_auth;
1745
+ int using_ecc = (alg_k & (SSL_kEECDH|SSL_kECDHr|SSL_kECDHe)) || (alg_a & SSL_aECDSA);
1746
+ using_ecc = using_ecc && (s->session->tlsext_ecpointformatlist != NULL);
1747
+
1748
+ if (using_ecc)
1749
+ {
1750
+ if (s->tlsext_ecpointformatlist != NULL) OPENSSL_free(s->tlsext_ecpointformatlist);
1751
+ if ((s->tlsext_ecpointformatlist = OPENSSL_malloc(3)) == NULL)
1752
+ {
1753
+ SSLerr(SSL_F_SSL_PREPARE_SERVERHELLO_TLSEXT,ERR_R_MALLOC_FAILURE);
1754
+ return -1;
1755
+ }
1756
+ s->tlsext_ecpointformatlist_length = 3;
1757
+ s->tlsext_ecpointformatlist[0] = TLSEXT_ECPOINTFORMAT_uncompressed;
1758
+ s->tlsext_ecpointformatlist[1] = TLSEXT_ECPOINTFORMAT_ansiX962_compressed_prime;
1759
+ s->tlsext_ecpointformatlist[2] = TLSEXT_ECPOINTFORMAT_ansiX962_compressed_char2;
1760
+ }
1761
+ #endif /* OPENSSL_NO_EC */
1762
+
1763
+ return 1;
1764
+ }
1765
+
1766
+ int ssl_check_clienthello_tlsext(SSL *s)
1767
+ {
1768
+ int ret=SSL_TLSEXT_ERR_NOACK;
1769
+ int al = SSL_AD_UNRECOGNIZED_NAME;
1770
+
1771
+ #ifndef OPENSSL_NO_EC
1772
+ /* The handling of the ECPointFormats extension is done elsewhere, namely in
1773
+ * ssl3_choose_cipher in s3_lib.c.
1774
+ */
1775
+ /* The handling of the EllipticCurves extension is done elsewhere, namely in
1776
+ * ssl3_choose_cipher in s3_lib.c.
1777
+ */
1778
+ #endif
1779
+
1780
+ if (s->ctx != NULL && s->ctx->tlsext_servername_callback != 0)
1781
+ ret = s->ctx->tlsext_servername_callback(s, &al, s->ctx->tlsext_servername_arg);
1782
+ else if (s->initial_ctx != NULL && s->initial_ctx->tlsext_servername_callback != 0)
1783
+ ret = s->initial_ctx->tlsext_servername_callback(s, &al, s->initial_ctx->tlsext_servername_arg);
1784
+
1785
+ /* If status request then ask callback what to do.
1786
+ * Note: this must be called after servername callbacks in case
1787
+ * the certificate has changed.
1788
+ */
1789
+ if ((s->tlsext_status_type != -1) && s->ctx && s->ctx->tlsext_status_cb)
1790
+ {
1791
+ int r;
1792
+ r = s->ctx->tlsext_status_cb(s, s->ctx->tlsext_status_arg);
1793
+ switch (r)
1794
+ {
1795
+ /* We don't want to send a status request response */
1796
+ case SSL_TLSEXT_ERR_NOACK:
1797
+ s->tlsext_status_expected = 0;
1798
+ break;
1799
+ /* status request response should be sent */
1800
+ case SSL_TLSEXT_ERR_OK:
1801
+ if (s->tlsext_ocsp_resp)
1802
+ s->tlsext_status_expected = 1;
1803
+ else
1804
+ s->tlsext_status_expected = 0;
1805
+ break;
1806
+ /* something bad happened */
1807
+ case SSL_TLSEXT_ERR_ALERT_FATAL:
1808
+ ret = SSL_TLSEXT_ERR_ALERT_FATAL;
1809
+ al = SSL_AD_INTERNAL_ERROR;
1810
+ goto err;
1811
+ }
1812
+ }
1813
+ else
1814
+ s->tlsext_status_expected = 0;
1815
+
1816
+ #ifdef TLSEXT_TYPE_opaque_prf_input
1817
+ {
1818
+ /* This sort of belongs into ssl_prepare_serverhello_tlsext(),
1819
+ * but we might be sending an alert in response to the client hello,
1820
+ * so this has to happen here in ssl_check_clienthello_tlsext(). */
1821
+
1822
+ int r = 1;
1823
+
1824
+ if (s->ctx->tlsext_opaque_prf_input_callback != 0)
1825
+ {
1826
+ r = s->ctx->tlsext_opaque_prf_input_callback(s, NULL, 0, s->ctx->tlsext_opaque_prf_input_callback_arg);
1827
+ if (!r)
1828
+ {
1829
+ ret = SSL_TLSEXT_ERR_ALERT_FATAL;
1830
+ al = SSL_AD_INTERNAL_ERROR;
1831
+ goto err;
1832
+ }
1833
+ }
1834
+
1835
+ if (s->s3->server_opaque_prf_input != NULL) /* shouldn't really happen */
1836
+ OPENSSL_free(s->s3->server_opaque_prf_input);
1837
+ s->s3->server_opaque_prf_input = NULL;
1838
+
1839
+ if (s->tlsext_opaque_prf_input != NULL)
1840
+ {
1841
+ if (s->s3->client_opaque_prf_input != NULL &&
1842
+ s->s3->client_opaque_prf_input_len == s->tlsext_opaque_prf_input_len)
1843
+ {
1844
+ /* can only use this extension if we have a server opaque PRF input
1845
+ * of the same length as the client opaque PRF input! */
1846
+
1847
+ if (s->tlsext_opaque_prf_input_len == 0)
1848
+ s->s3->server_opaque_prf_input = OPENSSL_malloc(1); /* dummy byte just to get non-NULL */
1849
+ else
1850
+ s->s3->server_opaque_prf_input = BUF_memdup(s->tlsext_opaque_prf_input, s->tlsext_opaque_prf_input_len);
1851
+ if (s->s3->server_opaque_prf_input == NULL)
1852
+ {
1853
+ ret = SSL_TLSEXT_ERR_ALERT_FATAL;
1854
+ al = SSL_AD_INTERNAL_ERROR;
1855
+ goto err;
1856
+ }
1857
+ s->s3->server_opaque_prf_input_len = s->tlsext_opaque_prf_input_len;
1858
+ }
1859
+ }
1860
+
1861
+ if (r == 2 && s->s3->server_opaque_prf_input == NULL)
1862
+ {
1863
+ /* The callback wants to enforce use of the extension,
1864
+ * but we can't do that with the client opaque PRF input;
1865
+ * abort the handshake.
1866
+ */
1867
+ ret = SSL_TLSEXT_ERR_ALERT_FATAL;
1868
+ al = SSL_AD_HANDSHAKE_FAILURE;
1869
+ }
1870
+ }
1871
+
1872
+ #endif
1873
+ err:
1874
+ switch (ret)
1875
+ {
1876
+ case SSL_TLSEXT_ERR_ALERT_FATAL:
1877
+ ssl3_send_alert(s,SSL3_AL_FATAL,al);
1878
+ return -1;
1879
+
1880
+ case SSL_TLSEXT_ERR_ALERT_WARNING:
1881
+ ssl3_send_alert(s,SSL3_AL_WARNING,al);
1882
+ return 1;
1883
+
1884
+ case SSL_TLSEXT_ERR_NOACK:
1885
+ s->servername_done=0;
1886
+ default:
1887
+ return 1;
1888
+ }
1889
+ }
1890
+
1891
+ int ssl_check_serverhello_tlsext(SSL *s)
1892
+ {
1893
+ int ret=SSL_TLSEXT_ERR_NOACK;
1894
+ int al = SSL_AD_UNRECOGNIZED_NAME;
1895
+
1896
+ #ifndef OPENSSL_NO_EC
1897
+ /* If we are client and using an elliptic curve cryptography cipher
1898
+ * suite, then if server returns an EC point formats lists extension
1899
+ * it must contain uncompressed.
1900
+ */
1901
+ unsigned long alg_k = s->s3->tmp.new_cipher->algorithm_mkey;
1902
+ unsigned long alg_a = s->s3->tmp.new_cipher->algorithm_auth;
1903
+ if ((s->tlsext_ecpointformatlist != NULL) && (s->tlsext_ecpointformatlist_length > 0) &&
1904
+ (s->session->tlsext_ecpointformatlist != NULL) && (s->session->tlsext_ecpointformatlist_length > 0) &&
1905
+ ((alg_k & (SSL_kEECDH|SSL_kECDHr|SSL_kECDHe)) || (alg_a & SSL_aECDSA)))
1906
+ {
1907
+ /* we are using an ECC cipher */
1908
+ size_t i;
1909
+ unsigned char *list;
1910
+ int found_uncompressed = 0;
1911
+ list = s->session->tlsext_ecpointformatlist;
1912
+ for (i = 0; i < s->session->tlsext_ecpointformatlist_length; i++)
1913
+ {
1914
+ if (*(list++) == TLSEXT_ECPOINTFORMAT_uncompressed)
1915
+ {
1916
+ found_uncompressed = 1;
1917
+ break;
1918
+ }
1919
+ }
1920
+ if (!found_uncompressed)
1921
+ {
1922
+ SSLerr(SSL_F_SSL_CHECK_SERVERHELLO_TLSEXT,SSL_R_TLS_INVALID_ECPOINTFORMAT_LIST);
1923
+ return -1;
1924
+ }
1925
+ }
1926
+ ret = SSL_TLSEXT_ERR_OK;
1927
+ #endif /* OPENSSL_NO_EC */
1928
+
1929
+ if (s->ctx != NULL && s->ctx->tlsext_servername_callback != 0)
1930
+ ret = s->ctx->tlsext_servername_callback(s, &al, s->ctx->tlsext_servername_arg);
1931
+ else if (s->initial_ctx != NULL && s->initial_ctx->tlsext_servername_callback != 0)
1932
+ ret = s->initial_ctx->tlsext_servername_callback(s, &al, s->initial_ctx->tlsext_servername_arg);
1933
+
1934
+ #ifdef TLSEXT_TYPE_opaque_prf_input
1935
+ if (s->s3->server_opaque_prf_input_len > 0)
1936
+ {
1937
+ /* This case may indicate that we, as a client, want to insist on using opaque PRF inputs.
1938
+ * So first verify that we really have a value from the server too. */
1939
+
1940
+ if (s->s3->server_opaque_prf_input == NULL)
1941
+ {
1942
+ ret = SSL_TLSEXT_ERR_ALERT_FATAL;
1943
+ al = SSL_AD_HANDSHAKE_FAILURE;
1944
+ }
1945
+
1946
+ /* Anytime the server *has* sent an opaque PRF input, we need to check
1947
+ * that we have a client opaque PRF input of the same size. */
1948
+ if (s->s3->client_opaque_prf_input == NULL ||
1949
+ s->s3->client_opaque_prf_input_len != s->s3->server_opaque_prf_input_len)
1950
+ {
1951
+ ret = SSL_TLSEXT_ERR_ALERT_FATAL;
1952
+ al = SSL_AD_ILLEGAL_PARAMETER;
1953
+ }
1954
+ }
1955
+ #endif
1956
+
1957
+ /* If we've requested certificate status and we wont get one
1958
+ * tell the callback
1959
+ */
1960
+ if ((s->tlsext_status_type != -1) && !(s->tlsext_status_expected)
1961
+ && s->ctx && s->ctx->tlsext_status_cb)
1962
+ {
1963
+ int r;
1964
+ /* Set resp to NULL, resplen to -1 so callback knows
1965
+ * there is no response.
1966
+ */
1967
+ if (s->tlsext_ocsp_resp)
1968
+ {
1969
+ OPENSSL_free(s->tlsext_ocsp_resp);
1970
+ s->tlsext_ocsp_resp = NULL;
1971
+ }
1972
+ s->tlsext_ocsp_resplen = -1;
1973
+ r = s->ctx->tlsext_status_cb(s, s->ctx->tlsext_status_arg);
1974
+ if (r == 0)
1975
+ {
1976
+ al = SSL_AD_BAD_CERTIFICATE_STATUS_RESPONSE;
1977
+ ret = SSL_TLSEXT_ERR_ALERT_FATAL;
1978
+ }
1979
+ if (r < 0)
1980
+ {
1981
+ al = SSL_AD_INTERNAL_ERROR;
1982
+ ret = SSL_TLSEXT_ERR_ALERT_FATAL;
1983
+ }
1984
+ }
1985
+
1986
+ switch (ret)
1987
+ {
1988
+ case SSL_TLSEXT_ERR_ALERT_FATAL:
1989
+ ssl3_send_alert(s,SSL3_AL_FATAL,al);
1990
+ return -1;
1991
+
1992
+ case SSL_TLSEXT_ERR_ALERT_WARNING:
1993
+ ssl3_send_alert(s,SSL3_AL_WARNING,al);
1994
+ return 1;
1995
+
1996
+ case SSL_TLSEXT_ERR_NOACK:
1997
+ s->servername_done=0;
1998
+ default:
1999
+ return 1;
2000
+ }
2001
+ }
2002
+
2003
+ /* Since the server cache lookup is done early on in the processing of the
2004
+ * ClientHello, and other operations depend on the result, we need to handle
2005
+ * any TLS session ticket extension at the same time.
2006
+ *
2007
+ * session_id: points at the session ID in the ClientHello. This code will
2008
+ * read past the end of this in order to parse out the session ticket
2009
+ * extension, if any.
2010
+ * len: the length of the session ID.
2011
+ * limit: a pointer to the first byte after the ClientHello.
2012
+ * ret: (output) on return, if a ticket was decrypted, then this is set to
2013
+ * point to the resulting session.
2014
+ *
2015
+ * If s->tls_session_secret_cb is set then we are expecting a pre-shared key
2016
+ * ciphersuite, in which case we have no use for session tickets and one will
2017
+ * never be decrypted, nor will s->tlsext_ticket_expected be set to 1.
2018
+ *
2019
+ * Returns:
2020
+ * -1: fatal error, either from parsing or decrypting the ticket.
2021
+ * 0: no ticket was found (or was ignored, based on settings).
2022
+ * 1: a zero length extension was found, indicating that the client supports
2023
+ * session tickets but doesn't currently have one to offer.
2024
+ * 2: either s->tls_session_secret_cb was set, or a ticket was offered but
2025
+ * couldn't be decrypted because of a non-fatal error.
2026
+ * 3: a ticket was successfully decrypted and *ret was set.
2027
+ *
2028
+ * Side effects:
2029
+ * Sets s->tlsext_ticket_expected to 1 if the server will have to issue
2030
+ * a new session ticket to the client because the client indicated support
2031
+ * (and s->tls_session_secret_cb is NULL) but the client either doesn't have
2032
+ * a session ticket or we couldn't use the one it gave us, or if
2033
+ * s->ctx->tlsext_ticket_key_cb asked to renew the client's ticket.
2034
+ * Otherwise, s->tlsext_ticket_expected is set to 0.
2035
+ */
2036
+ int tls1_process_ticket(SSL *s, unsigned char *session_id, int len,
2037
+ const unsigned char *limit, SSL_SESSION **ret)
2038
+ {
2039
+ /* Point after session ID in client hello */
2040
+ const unsigned char *p = session_id + len;
2041
+ unsigned short i;
2042
+
2043
+ *ret = NULL;
2044
+ s->tlsext_ticket_expected = 0;
2045
+
2046
+ /* If tickets disabled behave as if no ticket present
2047
+ * to permit stateful resumption.
2048
+ */
2049
+ if (SSL_get_options(s) & SSL_OP_NO_TICKET)
2050
+ return 0;
2051
+ if ((s->version <= SSL3_VERSION) || !limit)
2052
+ return 0;
2053
+ if (p >= limit)
2054
+ return -1;
2055
+ /* Skip past DTLS cookie */
2056
+ if (s->version == DTLS1_VERSION || s->version == DTLS1_BAD_VER)
2057
+ {
2058
+ i = *(p++);
2059
+ p+= i;
2060
+ if (p >= limit)
2061
+ return -1;
2062
+ }
2063
+ /* Skip past cipher list */
2064
+ n2s(p, i);
2065
+ p+= i;
2066
+ if (p >= limit)
2067
+ return -1;
2068
+ /* Skip past compression algorithm list */
2069
+ i = *(p++);
2070
+ p += i;
2071
+ if (p > limit)
2072
+ return -1;
2073
+ /* Now at start of extensions */
2074
+ if ((p + 2) >= limit)
2075
+ return 0;
2076
+ n2s(p, i);
2077
+ while ((p + 4) <= limit)
2078
+ {
2079
+ unsigned short type, size;
2080
+ n2s(p, type);
2081
+ n2s(p, size);
2082
+ if (p + size > limit)
2083
+ return 0;
2084
+ if (type == TLSEXT_TYPE_session_ticket)
2085
+ {
2086
+ int r;
2087
+ if (size == 0)
2088
+ {
2089
+ /* The client will accept a ticket but doesn't
2090
+ * currently have one. */
2091
+ s->tlsext_ticket_expected = 1;
2092
+ return 1;
2093
+ }
2094
+ if (s->tls_session_secret_cb)
2095
+ {
2096
+ /* Indicate that the ticket couldn't be
2097
+ * decrypted rather than generating the session
2098
+ * from ticket now, trigger abbreviated
2099
+ * handshake based on external mechanism to
2100
+ * calculate the master secret later. */
2101
+ return 2;
2102
+ }
2103
+ r = tls_decrypt_ticket(s, p, size, session_id, len, ret);
2104
+ switch (r)
2105
+ {
2106
+ case 2: /* ticket couldn't be decrypted */
2107
+ s->tlsext_ticket_expected = 1;
2108
+ return 2;
2109
+ case 3: /* ticket was decrypted */
2110
+ return r;
2111
+ case 4: /* ticket decrypted but need to renew */
2112
+ s->tlsext_ticket_expected = 1;
2113
+ return 3;
2114
+ default: /* fatal error */
2115
+ return -1;
2116
+ }
2117
+ }
2118
+ p += size;
2119
+ }
2120
+ return 0;
2121
+ }
2122
+
2123
+ /* tls_decrypt_ticket attempts to decrypt a session ticket.
2124
+ *
2125
+ * etick: points to the body of the session ticket extension.
2126
+ * eticklen: the length of the session tickets extenion.
2127
+ * sess_id: points at the session ID.
2128
+ * sesslen: the length of the session ID.
2129
+ * psess: (output) on return, if a ticket was decrypted, then this is set to
2130
+ * point to the resulting session.
2131
+ *
2132
+ * Returns:
2133
+ * -1: fatal error, either from parsing or decrypting the ticket.
2134
+ * 2: the ticket couldn't be decrypted.
2135
+ * 3: a ticket was successfully decrypted and *psess was set.
2136
+ * 4: same as 3, but the ticket needs to be renewed.
2137
+ */
2138
+ static int tls_decrypt_ticket(SSL *s, const unsigned char *etick, int eticklen,
2139
+ const unsigned char *sess_id, int sesslen,
2140
+ SSL_SESSION **psess)
2141
+ {
2142
+ SSL_SESSION *sess;
2143
+ unsigned char *sdec;
2144
+ const unsigned char *p;
2145
+ int slen, mlen, renew_ticket = 0;
2146
+ unsigned char tick_hmac[EVP_MAX_MD_SIZE];
2147
+ HMAC_CTX hctx;
2148
+ EVP_CIPHER_CTX ctx;
2149
+ SSL_CTX *tctx = s->initial_ctx;
2150
+ /* Need at least keyname + iv + some encrypted data */
2151
+ if (eticklen < 48)
2152
+ return 2;
2153
+ /* Initialize session ticket encryption and HMAC contexts */
2154
+ HMAC_CTX_init(&hctx);
2155
+ EVP_CIPHER_CTX_init(&ctx);
2156
+ if (tctx->tlsext_ticket_key_cb)
2157
+ {
2158
+ unsigned char *nctick = (unsigned char *)etick;
2159
+ int rv = tctx->tlsext_ticket_key_cb(s, nctick, nctick + 16,
2160
+ &ctx, &hctx, 0);
2161
+ if (rv < 0)
2162
+ return -1;
2163
+ if (rv == 0)
2164
+ return 2;
2165
+ if (rv == 2)
2166
+ renew_ticket = 1;
2167
+ }
2168
+ else
2169
+ {
2170
+ /* Check key name matches */
2171
+ if (memcmp(etick, tctx->tlsext_tick_key_name, 16))
2172
+ return 2;
2173
+ HMAC_Init_ex(&hctx, tctx->tlsext_tick_hmac_key, 16,
2174
+ tlsext_tick_md(), NULL);
2175
+ EVP_DecryptInit_ex(&ctx, EVP_aes_128_cbc(), NULL,
2176
+ tctx->tlsext_tick_aes_key, etick + 16);
2177
+ }
2178
+ /* Attempt to process session ticket, first conduct sanity and
2179
+ * integrity checks on ticket.
2180
+ */
2181
+ mlen = HMAC_size(&hctx);
2182
+ if (mlen < 0)
2183
+ {
2184
+ EVP_CIPHER_CTX_cleanup(&ctx);
2185
+ return -1;
2186
+ }
2187
+ eticklen -= mlen;
2188
+ /* Check HMAC of encrypted ticket */
2189
+ HMAC_Update(&hctx, etick, eticklen);
2190
+ HMAC_Final(&hctx, tick_hmac, NULL);
2191
+ HMAC_CTX_cleanup(&hctx);
2192
+ if (memcmp(tick_hmac, etick + eticklen, mlen))
2193
+ return 2;
2194
+ /* Attempt to decrypt session data */
2195
+ /* Move p after IV to start of encrypted ticket, update length */
2196
+ p = etick + 16 + EVP_CIPHER_CTX_iv_length(&ctx);
2197
+ eticklen -= 16 + EVP_CIPHER_CTX_iv_length(&ctx);
2198
+ sdec = OPENSSL_malloc(eticklen);
2199
+ if (!sdec)
2200
+ {
2201
+ EVP_CIPHER_CTX_cleanup(&ctx);
2202
+ return -1;
2203
+ }
2204
+ EVP_DecryptUpdate(&ctx, sdec, &slen, p, eticklen);
2205
+ if (EVP_DecryptFinal(&ctx, sdec + slen, &mlen) <= 0)
2206
+ return 2;
2207
+ slen += mlen;
2208
+ EVP_CIPHER_CTX_cleanup(&ctx);
2209
+ p = sdec;
2210
+
2211
+ sess = d2i_SSL_SESSION(NULL, &p, slen);
2212
+ OPENSSL_free(sdec);
2213
+ if (sess)
2214
+ {
2215
+ /* The session ID, if non-empty, is used by some clients to
2216
+ * detect that the ticket has been accepted. So we copy it to
2217
+ * the session structure. If it is empty set length to zero
2218
+ * as required by standard.
2219
+ */
2220
+ if (sesslen)
2221
+ memcpy(sess->session_id, sess_id, sesslen);
2222
+ sess->session_id_length = sesslen;
2223
+ *psess = sess;
2224
+ if (renew_ticket)
2225
+ return 4;
2226
+ else
2227
+ return 3;
2228
+ }
2229
+ ERR_clear_error();
2230
+ /* For session parse failure, indicate that we need to send a new
2231
+ * ticket. */
2232
+ return 2;
2233
+ }
2234
+
2235
+ /* Tables to translate from NIDs to TLS v1.2 ids */
2236
+
2237
+ typedef struct
2238
+ {
2239
+ int nid;
2240
+ int id;
2241
+ } tls12_lookup;
2242
+
2243
+ static tls12_lookup tls12_md[] = {
2244
+ #ifndef OPENSSL_NO_MD5
2245
+ {NID_md5, TLSEXT_hash_md5},
2246
+ #endif
2247
+ #ifndef OPENSSL_NO_SHA
2248
+ {NID_sha1, TLSEXT_hash_sha1},
2249
+ #endif
2250
+ #ifndef OPENSSL_NO_SHA256
2251
+ {NID_sha224, TLSEXT_hash_sha224},
2252
+ {NID_sha256, TLSEXT_hash_sha256},
2253
+ #endif
2254
+ #ifndef OPENSSL_NO_SHA512
2255
+ {NID_sha384, TLSEXT_hash_sha384},
2256
+ {NID_sha512, TLSEXT_hash_sha512}
2257
+ #endif
2258
+ };
2259
+
2260
+ static tls12_lookup tls12_sig[] = {
2261
+ #ifndef OPENSSL_NO_RSA
2262
+ {EVP_PKEY_RSA, TLSEXT_signature_rsa},
2263
+ #endif
2264
+ #ifndef OPENSSL_NO_DSA
2265
+ {EVP_PKEY_DSA, TLSEXT_signature_dsa},
2266
+ #endif
2267
+ #ifndef OPENSSL_NO_ECDSA
2268
+ {EVP_PKEY_EC, TLSEXT_signature_ecdsa}
2269
+ #endif
2270
+ };
2271
+
2272
+ static int tls12_find_id(int nid, tls12_lookup *table, size_t tlen)
2273
+ {
2274
+ size_t i;
2275
+ for (i = 0; i < tlen; i++)
2276
+ {
2277
+ if (table[i].nid == nid)
2278
+ return table[i].id;
2279
+ }
2280
+ return -1;
2281
+ }
2282
+ #if 0
2283
+ static int tls12_find_nid(int id, tls12_lookup *table, size_t tlen)
2284
+ {
2285
+ size_t i;
2286
+ for (i = 0; i < tlen; i++)
2287
+ {
2288
+ if (table[i].id == id)
2289
+ return table[i].nid;
2290
+ }
2291
+ return -1;
2292
+ }
2293
+ #endif
2294
+
2295
+ int tls12_get_sigandhash(unsigned char *p, const EVP_PKEY *pk, const EVP_MD *md)
2296
+ {
2297
+ int sig_id, md_id;
2298
+ if (!md)
2299
+ return 0;
2300
+ md_id = tls12_find_id(EVP_MD_type(md), tls12_md,
2301
+ sizeof(tls12_md)/sizeof(tls12_lookup));
2302
+ if (md_id == -1)
2303
+ return 0;
2304
+ sig_id = tls12_get_sigid(pk);
2305
+ if (sig_id == -1)
2306
+ return 0;
2307
+ p[0] = (unsigned char)md_id;
2308
+ p[1] = (unsigned char)sig_id;
2309
+ return 1;
2310
+ }
2311
+
2312
+ int tls12_get_sigid(const EVP_PKEY *pk)
2313
+ {
2314
+ return tls12_find_id(pk->type, tls12_sig,
2315
+ sizeof(tls12_sig)/sizeof(tls12_lookup));
2316
+ }
2317
+
2318
+ const EVP_MD *tls12_get_hash(unsigned char hash_alg)
2319
+ {
2320
+ switch(hash_alg)
2321
+ {
2322
+ #ifndef OPENSSL_NO_MD5
2323
+ case TLSEXT_hash_md5:
2324
+ #ifdef OPENSSL_FIPS
2325
+ if (FIPS_mode())
2326
+ return NULL;
2327
+ #endif
2328
+ return EVP_md5();
2329
+ #endif
2330
+ #ifndef OPENSSL_NO_SHA
2331
+ case TLSEXT_hash_sha1:
2332
+ return EVP_sha1();
2333
+ #endif
2334
+ #ifndef OPENSSL_NO_SHA256
2335
+ case TLSEXT_hash_sha224:
2336
+ return EVP_sha224();
2337
+
2338
+ case TLSEXT_hash_sha256:
2339
+ return EVP_sha256();
2340
+ #endif
2341
+ #ifndef OPENSSL_NO_SHA512
2342
+ case TLSEXT_hash_sha384:
2343
+ return EVP_sha384();
2344
+
2345
+ case TLSEXT_hash_sha512:
2346
+ return EVP_sha512();
2347
+ #endif
2348
+ default:
2349
+ return NULL;
2350
+
2351
+ }
2352
+ }
2353
+
2354
+ /* Set preferred digest for each key type */
2355
+
2356
+ int tls1_process_sigalgs(SSL *s, const unsigned char *data, int dsize)
2357
+ {
2358
+ int i, idx;
2359
+ const EVP_MD *md;
2360
+ CERT *c = s->cert;
2361
+ /* Extension ignored for TLS versions below 1.2 */
2362
+ if (TLS1_get_version(s) < TLS1_2_VERSION)
2363
+ return 1;
2364
+ /* Should never happen */
2365
+ if (!c)
2366
+ return 0;
2367
+
2368
+ c->pkeys[SSL_PKEY_DSA_SIGN].digest = NULL;
2369
+ c->pkeys[SSL_PKEY_RSA_SIGN].digest = NULL;
2370
+ c->pkeys[SSL_PKEY_RSA_ENC].digest = NULL;
2371
+ c->pkeys[SSL_PKEY_ECC].digest = NULL;
2372
+
2373
+ for (i = 0; i < dsize; i += 2)
2374
+ {
2375
+ unsigned char hash_alg = data[i], sig_alg = data[i+1];
2376
+
2377
+ switch(sig_alg)
2378
+ {
2379
+ #ifndef OPENSSL_NO_RSA
2380
+ case TLSEXT_signature_rsa:
2381
+ idx = SSL_PKEY_RSA_SIGN;
2382
+ break;
2383
+ #endif
2384
+ #ifndef OPENSSL_NO_DSA
2385
+ case TLSEXT_signature_dsa:
2386
+ idx = SSL_PKEY_DSA_SIGN;
2387
+ break;
2388
+ #endif
2389
+ #ifndef OPENSSL_NO_ECDSA
2390
+ case TLSEXT_signature_ecdsa:
2391
+ idx = SSL_PKEY_ECC;
2392
+ break;
2393
+ #endif
2394
+ default:
2395
+ continue;
2396
+ }
2397
+
2398
+ if (c->pkeys[idx].digest == NULL)
2399
+ {
2400
+ md = tls12_get_hash(hash_alg);
2401
+ if (md)
2402
+ {
2403
+ c->pkeys[idx].digest = md;
2404
+ if (idx == SSL_PKEY_RSA_SIGN)
2405
+ c->pkeys[SSL_PKEY_RSA_ENC].digest = md;
2406
+ }
2407
+ }
2408
+
2409
+ }
2410
+
2411
+
2412
+ /* Set any remaining keys to default values. NOTE: if alg is not
2413
+ * supported it stays as NULL.
2414
+ */
2415
+ #ifndef OPENSSL_NO_DSA
2416
+ if (!c->pkeys[SSL_PKEY_DSA_SIGN].digest)
2417
+ c->pkeys[SSL_PKEY_DSA_SIGN].digest = EVP_dss1();
2418
+ #endif
2419
+ #ifndef OPENSSL_NO_RSA
2420
+ if (!c->pkeys[SSL_PKEY_RSA_SIGN].digest)
2421
+ {
2422
+ c->pkeys[SSL_PKEY_RSA_SIGN].digest = EVP_sha1();
2423
+ c->pkeys[SSL_PKEY_RSA_ENC].digest = EVP_sha1();
2424
+ }
2425
+ #endif
2426
+ #ifndef OPENSSL_NO_ECDSA
2427
+ if (!c->pkeys[SSL_PKEY_ECC].digest)
2428
+ c->pkeys[SSL_PKEY_ECC].digest = EVP_ecdsa();
2429
+ #endif
2430
+ return 1;
2431
+ }
2432
+
2433
+ #endif
2434
+
2435
+ #ifndef OPENSSL_NO_HEARTBEATS
2436
+ int
2437
+ tls1_process_heartbeat(SSL *s)
2438
+ {
2439
+ unsigned char *p = &s->s3->rrec.data[0], *pl;
2440
+ unsigned short hbtype;
2441
+ unsigned int payload;
2442
+ unsigned int padding = 16; /* Use minimum padding */
2443
+
2444
+ /* Read type and payload length first */
2445
+ hbtype = *p++;
2446
+ n2s(p, payload);
2447
+ pl = p;
2448
+
2449
+ if (s->msg_callback)
2450
+ s->msg_callback(0, s->version, TLS1_RT_HEARTBEAT,
2451
+ &s->s3->rrec.data[0], s->s3->rrec.length,
2452
+ s, s->msg_callback_arg);
2453
+
2454
+ if (hbtype == TLS1_HB_REQUEST)
2455
+ {
2456
+ unsigned char *buffer, *bp;
2457
+ int r;
2458
+
2459
+ /* Allocate memory for the response, size is 1 bytes
2460
+ * message type, plus 2 bytes payload length, plus
2461
+ * payload, plus padding
2462
+ */
2463
+ buffer = OPENSSL_malloc(1 + 2 + payload + padding);
2464
+ bp = buffer;
2465
+
2466
+ /* Enter response type, length and copy payload */
2467
+ *bp++ = TLS1_HB_RESPONSE;
2468
+ s2n(payload, bp);
2469
+ memcpy(bp, pl, payload);
2470
+ bp += payload;
2471
+ /* Random padding */
2472
+ RAND_pseudo_bytes(bp, padding);
2473
+
2474
+ r = ssl3_write_bytes(s, TLS1_RT_HEARTBEAT, buffer, 3 + payload + padding);
2475
+
2476
+ if (r >= 0 && s->msg_callback)
2477
+ s->msg_callback(1, s->version, TLS1_RT_HEARTBEAT,
2478
+ buffer, 3 + payload + padding,
2479
+ s, s->msg_callback_arg);
2480
+
2481
+ OPENSSL_free(buffer);
2482
+
2483
+ if (r < 0)
2484
+ return r;
2485
+ }
2486
+ else if (hbtype == TLS1_HB_RESPONSE)
2487
+ {
2488
+ unsigned int seq;
2489
+
2490
+ /* We only send sequence numbers (2 bytes unsigned int),
2491
+ * and 16 random bytes, so we just try to read the
2492
+ * sequence number */
2493
+ n2s(pl, seq);
2494
+
2495
+ if (payload == 18 && seq == s->tlsext_hb_seq)
2496
+ {
2497
+ s->tlsext_hb_seq++;
2498
+ s->tlsext_hb_pending = 0;
2499
+ }
2500
+ }
2501
+
2502
+ return 0;
2503
+ }
2504
+
2505
+ int
2506
+ tls1_heartbeat(SSL *s)
2507
+ {
2508
+ unsigned char *buf, *p;
2509
+ int ret;
2510
+ unsigned int payload = 18; /* Sequence number + random bytes */
2511
+ unsigned int padding = 16; /* Use minimum padding */
2512
+
2513
+ /* Only send if peer supports and accepts HB requests... */
2514
+ if (!(s->tlsext_heartbeat & SSL_TLSEXT_HB_ENABLED) ||
2515
+ s->tlsext_heartbeat & SSL_TLSEXT_HB_DONT_SEND_REQUESTS)
2516
+ {
2517
+ SSLerr(SSL_F_TLS1_HEARTBEAT,SSL_R_TLS_HEARTBEAT_PEER_DOESNT_ACCEPT);
2518
+ return -1;
2519
+ }
2520
+
2521
+ /* ...and there is none in flight yet... */
2522
+ if (s->tlsext_hb_pending)
2523
+ {
2524
+ SSLerr(SSL_F_TLS1_HEARTBEAT,SSL_R_TLS_HEARTBEAT_PENDING);
2525
+ return -1;
2526
+ }
2527
+
2528
+ /* ...and no handshake in progress. */
2529
+ if (SSL_in_init(s) || s->in_handshake)
2530
+ {
2531
+ SSLerr(SSL_F_TLS1_HEARTBEAT,SSL_R_UNEXPECTED_MESSAGE);
2532
+ return -1;
2533
+ }
2534
+
2535
+ /* Check if padding is too long, payload and padding
2536
+ * must not exceed 2^14 - 3 = 16381 bytes in total.
2537
+ */
2538
+ OPENSSL_assert(payload + padding <= 16381);
2539
+
2540
+ /* Create HeartBeat message, we just use a sequence number
2541
+ * as payload to distuingish different messages and add
2542
+ * some random stuff.
2543
+ * - Message Type, 1 byte
2544
+ * - Payload Length, 2 bytes (unsigned int)
2545
+ * - Payload, the sequence number (2 bytes uint)
2546
+ * - Payload, random bytes (16 bytes uint)
2547
+ * - Padding
2548
+ */
2549
+ buf = OPENSSL_malloc(1 + 2 + payload + padding);
2550
+ p = buf;
2551
+ /* Message Type */
2552
+ *p++ = TLS1_HB_REQUEST;
2553
+ /* Payload length (18 bytes here) */
2554
+ s2n(payload, p);
2555
+ /* Sequence number */
2556
+ s2n(s->tlsext_hb_seq, p);
2557
+ /* 16 random bytes */
2558
+ RAND_pseudo_bytes(p, 16);
2559
+ p += 16;
2560
+ /* Random padding */
2561
+ RAND_pseudo_bytes(p, padding);
2562
+
2563
+ ret = ssl3_write_bytes(s, TLS1_RT_HEARTBEAT, buf, 3 + payload + padding);
2564
+ if (ret >= 0)
2565
+ {
2566
+ if (s->msg_callback)
2567
+ s->msg_callback(1, s->version, TLS1_RT_HEARTBEAT,
2568
+ buf, 3 + payload + padding,
2569
+ s, s->msg_callback_arg);
2570
+
2571
+ s->tlsext_hb_pending = 1;
2572
+ }
2573
+
2574
+ OPENSSL_free(buf);
2575
+
2576
+ return ret;
2577
+ }
2578
+ #endif