诸暨麻将添加redis
您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符
 
 
 
 
 
 

1900 行
65 KiB

  1. /***************************************************************************
  2. * _ _ ____ _
  3. * Project ___| | | | _ \| |
  4. * / __| | | | |_) | |
  5. * | (__| |_| | _ <| |___
  6. * \___|\___/|_| \_\_____|
  7. *
  8. * Copyright (C) 2012-2013, Nick Zitzmann, <nickzman@gmail.com>.
  9. * Copyright (C) 2012-2013, Daniel Stenberg, <daniel@haxx.se>, et al.
  10. *
  11. * This software is licensed as described in the file COPYING, which
  12. * you should have received as part of this distribution. The terms
  13. * are also available at http://curl.haxx.se/docs/copyright.html.
  14. *
  15. * You may opt to use, copy, modify, merge, publish, distribute and/or sell
  16. * copies of the Software, and permit persons to whom the Software is
  17. * furnished to do so, under the terms of the COPYING file.
  18. *
  19. * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
  20. * KIND, either express or implied.
  21. *
  22. ***************************************************************************/
  23. /*
  24. * Source file for all iOS and Mac OS X SecureTransport-specific code for the
  25. * TLS/SSL layer. No code but sslgen.c should ever call or use these functions.
  26. */
  27. #include "curl_setup.h"
  28. #ifdef USE_DARWINSSL
  29. #ifdef HAVE_LIMITS_H
  30. #include <limits.h>
  31. #endif
  32. #include <Security/Security.h>
  33. #include <Security/SecureTransport.h>
  34. #include <CoreFoundation/CoreFoundation.h>
  35. #include <CommonCrypto/CommonDigest.h>
  36. /* The Security framework has changed greatly between iOS and different OS X
  37. versions, and we will try to support as many of them as we can (back to
  38. Leopard and iOS 5) by using macros and weak-linking.
  39. IMPORTANT: If TLS 1.1 and 1.2 support are important for you on OS X, then
  40. you must build this project against the 10.8 SDK or later. */
  41. #if (TARGET_OS_MAC && !(TARGET_OS_EMBEDDED || TARGET_OS_IPHONE))
  42. #if MAC_OS_X_VERSION_MAX_ALLOWED < 1050
  43. #error "The darwinssl back-end requires Leopard or later."
  44. #endif /* MAC_OS_X_VERSION_MAX_ALLOWED < 1050 */
  45. #define CURL_BUILD_IOS 0
  46. #define CURL_BUILD_MAC 1
  47. /* This is the maximum API level we are allowed to use when building: */
  48. #define CURL_BUILD_MAC_10_5 MAC_OS_X_VERSION_MAX_ALLOWED >= 1050
  49. #define CURL_BUILD_MAC_10_6 MAC_OS_X_VERSION_MAX_ALLOWED >= 1060
  50. #define CURL_BUILD_MAC_10_7 MAC_OS_X_VERSION_MAX_ALLOWED >= 1070
  51. #define CURL_BUILD_MAC_10_8 MAC_OS_X_VERSION_MAX_ALLOWED >= 1080
  52. /* These macros mean "the following code is present to allow runtime backward
  53. compatibility with at least this cat or earlier":
  54. (You set this at build-time by setting the MACOSX_DEPLOYMENT_TARGET
  55. environmental variable.) */
  56. #define CURL_SUPPORT_MAC_10_5 MAC_OS_X_VERSION_MIN_REQUIRED <= 1050
  57. #define CURL_SUPPORT_MAC_10_6 MAC_OS_X_VERSION_MIN_REQUIRED <= 1060
  58. #define CURL_SUPPORT_MAC_10_7 MAC_OS_X_VERSION_MIN_REQUIRED <= 1070
  59. #define CURL_SUPPORT_MAC_10_8 MAC_OS_X_VERSION_MIN_REQUIRED <= 1080
  60. #elif TARGET_OS_EMBEDDED || TARGET_OS_IPHONE
  61. #define CURL_BUILD_IOS 1
  62. #define CURL_BUILD_MAC 0
  63. #define CURL_BUILD_MAC_10_5 0
  64. #define CURL_BUILD_MAC_10_6 0
  65. #define CURL_BUILD_MAC_10_7 0
  66. #define CURL_BUILD_MAC_10_8 0
  67. #define CURL_SUPPORT_MAC_10_5 0
  68. #define CURL_SUPPORT_MAC_10_6 0
  69. #define CURL_SUPPORT_MAC_10_7 0
  70. #define CURL_SUPPORT_MAC_10_8 0
  71. #else
  72. #error "The darwinssl back-end requires iOS or OS X."
  73. #endif /* (TARGET_OS_MAC && !(TARGET_OS_EMBEDDED || TARGET_OS_IPHONE)) */
  74. #if CURL_BUILD_MAC
  75. #include <sys/sysctl.h>
  76. #endif /* CURL_BUILD_MAC */
  77. #include "urldata.h"
  78. #include "sendf.h"
  79. #include "inet_pton.h"
  80. #include "connect.h"
  81. #include "select.h"
  82. #include "sslgen.h"
  83. #include "curl_darwinssl.h"
  84. #define _MPRINTF_REPLACE /* use our functions only */
  85. #include <curl/mprintf.h>
  86. #include "curl_memory.h"
  87. /* The last #include file should be: */
  88. #include "memdebug.h"
  89. /* From MacTypes.h (which we can't include because it isn't present in iOS: */
  90. #define ioErr -36
  91. #define paramErr -50
  92. /* The following two functions were ripped from Apple sample code,
  93. * with some modifications: */
  94. static OSStatus SocketRead(SSLConnectionRef connection,
  95. void *data, /* owned by
  96. * caller, data
  97. * RETURNED */
  98. size_t *dataLength) /* IN/OUT */
  99. {
  100. size_t bytesToGo = *dataLength;
  101. size_t initLen = bytesToGo;
  102. UInt8 *currData = (UInt8 *)data;
  103. /*int sock = *(int *)connection;*/
  104. struct ssl_connect_data *connssl = (struct ssl_connect_data *)connection;
  105. int sock = connssl->ssl_sockfd;
  106. OSStatus rtn = noErr;
  107. size_t bytesRead;
  108. ssize_t rrtn;
  109. int theErr;
  110. *dataLength = 0;
  111. for(;;) {
  112. bytesRead = 0;
  113. rrtn = read(sock, currData, bytesToGo);
  114. if(rrtn <= 0) {
  115. /* this is guesswork... */
  116. theErr = errno;
  117. if(rrtn == 0) { /* EOF = server hung up */
  118. /* the framework will turn this into errSSLClosedNoNotify */
  119. rtn = errSSLClosedGraceful;
  120. }
  121. else /* do the switch */
  122. switch(theErr) {
  123. case ENOENT:
  124. /* connection closed */
  125. rtn = errSSLClosedGraceful;
  126. break;
  127. case ECONNRESET:
  128. rtn = errSSLClosedAbort;
  129. break;
  130. case EAGAIN:
  131. rtn = errSSLWouldBlock;
  132. connssl->ssl_direction = false;
  133. break;
  134. default:
  135. rtn = ioErr;
  136. break;
  137. }
  138. break;
  139. }
  140. else {
  141. bytesRead = rrtn;
  142. }
  143. bytesToGo -= bytesRead;
  144. currData += bytesRead;
  145. if(bytesToGo == 0) {
  146. /* filled buffer with incoming data, done */
  147. break;
  148. }
  149. }
  150. *dataLength = initLen - bytesToGo;
  151. return rtn;
  152. }
  153. static OSStatus SocketWrite(SSLConnectionRef connection,
  154. const void *data,
  155. size_t *dataLength) /* IN/OUT */
  156. {
  157. size_t bytesSent = 0;
  158. /*int sock = *(int *)connection;*/
  159. struct ssl_connect_data *connssl = (struct ssl_connect_data *)connection;
  160. int sock = connssl->ssl_sockfd;
  161. ssize_t length;
  162. size_t dataLen = *dataLength;
  163. const UInt8 *dataPtr = (UInt8 *)data;
  164. OSStatus ortn;
  165. int theErr;
  166. *dataLength = 0;
  167. do {
  168. length = write(sock,
  169. (char*)dataPtr + bytesSent,
  170. dataLen - bytesSent);
  171. } while((length > 0) &&
  172. ( (bytesSent += length) < dataLen) );
  173. if(length <= 0) {
  174. theErr = errno;
  175. if(theErr == EAGAIN) {
  176. ortn = errSSLWouldBlock;
  177. connssl->ssl_direction = true;
  178. }
  179. else {
  180. ortn = ioErr;
  181. }
  182. }
  183. else {
  184. ortn = noErr;
  185. }
  186. *dataLength = bytesSent;
  187. return ortn;
  188. }
  189. CF_INLINE const char *SSLCipherNameForNumber(SSLCipherSuite cipher) {
  190. switch (cipher) {
  191. /* SSL version 3.0 */
  192. case SSL_RSA_WITH_NULL_MD5:
  193. return "SSL_RSA_WITH_NULL_MD5";
  194. break;
  195. case SSL_RSA_WITH_NULL_SHA:
  196. return "SSL_RSA_WITH_NULL_SHA";
  197. break;
  198. case SSL_RSA_EXPORT_WITH_RC4_40_MD5:
  199. return "SSL_RSA_EXPORT_WITH_RC4_40_MD5";
  200. break;
  201. case SSL_RSA_WITH_RC4_128_MD5:
  202. return "SSL_RSA_WITH_RC4_128_MD5";
  203. break;
  204. case SSL_RSA_WITH_RC4_128_SHA:
  205. return "SSL_RSA_WITH_RC4_128_SHA";
  206. break;
  207. case SSL_RSA_EXPORT_WITH_RC2_CBC_40_MD5:
  208. return "SSL_RSA_EXPORT_WITH_RC2_CBC_40_MD5";
  209. break;
  210. case SSL_RSA_WITH_IDEA_CBC_SHA:
  211. return "SSL_RSA_WITH_IDEA_CBC_SHA";
  212. break;
  213. case SSL_RSA_EXPORT_WITH_DES40_CBC_SHA:
  214. return "SSL_RSA_EXPORT_WITH_DES40_CBC_SHA";
  215. break;
  216. case SSL_RSA_WITH_DES_CBC_SHA:
  217. return "SSL_RSA_WITH_DES_CBC_SHA";
  218. break;
  219. case SSL_RSA_WITH_3DES_EDE_CBC_SHA:
  220. return "SSL_RSA_WITH_3DES_EDE_CBC_SHA";
  221. break;
  222. case SSL_DH_DSS_EXPORT_WITH_DES40_CBC_SHA:
  223. return "SSL_DH_DSS_EXPORT_WITH_DES40_CBC_SHA";
  224. break;
  225. case SSL_DH_DSS_WITH_DES_CBC_SHA:
  226. return "SSL_DH_DSS_WITH_DES_CBC_SHA";
  227. break;
  228. case SSL_DH_DSS_WITH_3DES_EDE_CBC_SHA:
  229. return "SSL_DH_DSS_WITH_3DES_EDE_CBC_SHA";
  230. break;
  231. case SSL_DH_RSA_EXPORT_WITH_DES40_CBC_SHA:
  232. return "SSL_DH_RSA_EXPORT_WITH_DES40_CBC_SHA";
  233. break;
  234. case SSL_DH_RSA_WITH_DES_CBC_SHA:
  235. return "SSL_DH_RSA_WITH_DES_CBC_SHA";
  236. break;
  237. case SSL_DH_RSA_WITH_3DES_EDE_CBC_SHA:
  238. return "SSL_DH_RSA_WITH_3DES_EDE_CBC_SHA";
  239. break;
  240. case SSL_DHE_DSS_EXPORT_WITH_DES40_CBC_SHA:
  241. return "SSL_DHE_DSS_EXPORT_WITH_DES40_CBC_SHA";
  242. break;
  243. case SSL_DHE_DSS_WITH_DES_CBC_SHA:
  244. return "SSL_DHE_DSS_WITH_DES_CBC_SHA";
  245. break;
  246. case SSL_DHE_DSS_WITH_3DES_EDE_CBC_SHA:
  247. return "SSL_DHE_DSS_WITH_3DES_EDE_CBC_SHA";
  248. break;
  249. case SSL_DHE_RSA_EXPORT_WITH_DES40_CBC_SHA:
  250. return "SSL_DHE_RSA_EXPORT_WITH_DES40_CBC_SHA";
  251. break;
  252. case SSL_DHE_RSA_WITH_DES_CBC_SHA:
  253. return "SSL_DHE_RSA_WITH_DES_CBC_SHA";
  254. break;
  255. case SSL_DHE_RSA_WITH_3DES_EDE_CBC_SHA:
  256. return "SSL_DHE_RSA_WITH_3DES_EDE_CBC_SHA";
  257. break;
  258. case SSL_DH_anon_EXPORT_WITH_RC4_40_MD5:
  259. return "SSL_DH_anon_EXPORT_WITH_RC4_40_MD5";
  260. break;
  261. case SSL_DH_anon_WITH_RC4_128_MD5:
  262. return "SSL_DH_anon_WITH_RC4_128_MD5";
  263. break;
  264. case SSL_DH_anon_EXPORT_WITH_DES40_CBC_SHA:
  265. return "SSL_DH_anon_EXPORT_WITH_DES40_CBC_SHA";
  266. break;
  267. case SSL_DH_anon_WITH_DES_CBC_SHA:
  268. return "SSL_DH_anon_WITH_DES_CBC_SHA";
  269. break;
  270. case SSL_DH_anon_WITH_3DES_EDE_CBC_SHA:
  271. return "SSL_DH_anon_WITH_3DES_EDE_CBC_SHA";
  272. break;
  273. case SSL_FORTEZZA_DMS_WITH_NULL_SHA:
  274. return "SSL_FORTEZZA_DMS_WITH_NULL_SHA";
  275. break;
  276. case SSL_FORTEZZA_DMS_WITH_FORTEZZA_CBC_SHA:
  277. return "SSL_FORTEZZA_DMS_WITH_FORTEZZA_CBC_SHA";
  278. break;
  279. /* TLS 1.0 with AES (RFC 3268)
  280. (Apparently these are used in SSLv3 implementations as well.) */
  281. case TLS_RSA_WITH_AES_128_CBC_SHA:
  282. return "TLS_RSA_WITH_AES_128_CBC_SHA";
  283. break;
  284. case TLS_DH_DSS_WITH_AES_128_CBC_SHA:
  285. return "TLS_DH_DSS_WITH_AES_128_CBC_SHA";
  286. break;
  287. case TLS_DH_RSA_WITH_AES_128_CBC_SHA:
  288. return "TLS_DH_RSA_WITH_AES_128_CBC_SHA";
  289. break;
  290. case TLS_DHE_DSS_WITH_AES_128_CBC_SHA:
  291. return "TLS_DHE_DSS_WITH_AES_128_CBC_SHA";
  292. break;
  293. case TLS_DHE_RSA_WITH_AES_128_CBC_SHA:
  294. return "TLS_DHE_RSA_WITH_AES_128_CBC_SHA";
  295. break;
  296. case TLS_DH_anon_WITH_AES_128_CBC_SHA:
  297. return "TLS_DH_anon_WITH_AES_128_CBC_SHA";
  298. break;
  299. case TLS_RSA_WITH_AES_256_CBC_SHA:
  300. return "TLS_RSA_WITH_AES_256_CBC_SHA";
  301. break;
  302. case TLS_DH_DSS_WITH_AES_256_CBC_SHA:
  303. return "TLS_DH_DSS_WITH_AES_256_CBC_SHA";
  304. break;
  305. case TLS_DH_RSA_WITH_AES_256_CBC_SHA:
  306. return "TLS_DH_RSA_WITH_AES_256_CBC_SHA";
  307. break;
  308. case TLS_DHE_DSS_WITH_AES_256_CBC_SHA:
  309. return "TLS_DHE_DSS_WITH_AES_256_CBC_SHA";
  310. break;
  311. case TLS_DHE_RSA_WITH_AES_256_CBC_SHA:
  312. return "TLS_DHE_RSA_WITH_AES_256_CBC_SHA";
  313. break;
  314. case TLS_DH_anon_WITH_AES_256_CBC_SHA:
  315. return "TLS_DH_anon_WITH_AES_256_CBC_SHA";
  316. break;
  317. /* SSL version 2.0 */
  318. case SSL_RSA_WITH_RC2_CBC_MD5:
  319. return "SSL_RSA_WITH_RC2_CBC_MD5";
  320. break;
  321. case SSL_RSA_WITH_IDEA_CBC_MD5:
  322. return "SSL_RSA_WITH_IDEA_CBC_MD5";
  323. break;
  324. case SSL_RSA_WITH_DES_CBC_MD5:
  325. return "SSL_RSA_WITH_DES_CBC_MD5";
  326. break;
  327. case SSL_RSA_WITH_3DES_EDE_CBC_MD5:
  328. return "SSL_RSA_WITH_3DES_EDE_CBC_MD5";
  329. break;
  330. }
  331. return "SSL_NULL_WITH_NULL_NULL";
  332. }
  333. CF_INLINE const char *TLSCipherNameForNumber(SSLCipherSuite cipher) {
  334. switch(cipher) {
  335. /* TLS 1.0 with AES (RFC 3268) */
  336. case TLS_RSA_WITH_AES_128_CBC_SHA:
  337. return "TLS_RSA_WITH_AES_128_CBC_SHA";
  338. break;
  339. case TLS_DH_DSS_WITH_AES_128_CBC_SHA:
  340. return "TLS_DH_DSS_WITH_AES_128_CBC_SHA";
  341. break;
  342. case TLS_DH_RSA_WITH_AES_128_CBC_SHA:
  343. return "TLS_DH_RSA_WITH_AES_128_CBC_SHA";
  344. break;
  345. case TLS_DHE_DSS_WITH_AES_128_CBC_SHA:
  346. return "TLS_DHE_DSS_WITH_AES_128_CBC_SHA";
  347. break;
  348. case TLS_DHE_RSA_WITH_AES_128_CBC_SHA:
  349. return "TLS_DHE_RSA_WITH_AES_128_CBC_SHA";
  350. break;
  351. case TLS_DH_anon_WITH_AES_128_CBC_SHA:
  352. return "TLS_DH_anon_WITH_AES_128_CBC_SHA";
  353. break;
  354. case TLS_RSA_WITH_AES_256_CBC_SHA:
  355. return "TLS_RSA_WITH_AES_256_CBC_SHA";
  356. break;
  357. case TLS_DH_DSS_WITH_AES_256_CBC_SHA:
  358. return "TLS_DH_DSS_WITH_AES_256_CBC_SHA";
  359. break;
  360. case TLS_DH_RSA_WITH_AES_256_CBC_SHA:
  361. return "TLS_DH_RSA_WITH_AES_256_CBC_SHA";
  362. break;
  363. case TLS_DHE_DSS_WITH_AES_256_CBC_SHA:
  364. return "TLS_DHE_DSS_WITH_AES_256_CBC_SHA";
  365. break;
  366. case TLS_DHE_RSA_WITH_AES_256_CBC_SHA:
  367. return "TLS_DHE_RSA_WITH_AES_256_CBC_SHA";
  368. break;
  369. case TLS_DH_anon_WITH_AES_256_CBC_SHA:
  370. return "TLS_DH_anon_WITH_AES_256_CBC_SHA";
  371. break;
  372. #if CURL_BUILD_MAC_10_6 || CURL_BUILD_IOS
  373. /* TLS 1.0 with ECDSA (RFC 4492) */
  374. case TLS_ECDH_ECDSA_WITH_NULL_SHA:
  375. return "TLS_ECDH_ECDSA_WITH_NULL_SHA";
  376. break;
  377. case TLS_ECDH_ECDSA_WITH_RC4_128_SHA:
  378. return "TLS_ECDH_ECDSA_WITH_RC4_128_SHA";
  379. break;
  380. case TLS_ECDH_ECDSA_WITH_3DES_EDE_CBC_SHA:
  381. return "TLS_ECDH_ECDSA_WITH_3DES_EDE_CBC_SHA";
  382. break;
  383. case TLS_ECDH_ECDSA_WITH_AES_128_CBC_SHA:
  384. return "TLS_ECDH_ECDSA_WITH_AES_128_CBC_SHA";
  385. break;
  386. case TLS_ECDH_ECDSA_WITH_AES_256_CBC_SHA:
  387. return "TLS_ECDH_ECDSA_WITH_AES_256_CBC_SHA";
  388. break;
  389. case TLS_ECDHE_ECDSA_WITH_NULL_SHA:
  390. return "TLS_ECDHE_ECDSA_WITH_NULL_SHA";
  391. break;
  392. case TLS_ECDHE_ECDSA_WITH_RC4_128_SHA:
  393. return "TLS_ECDHE_ECDSA_WITH_RC4_128_SHA";
  394. break;
  395. case TLS_ECDHE_ECDSA_WITH_3DES_EDE_CBC_SHA:
  396. return "TLS_ECDHE_ECDSA_WITH_3DES_EDE_CBC_SHA";
  397. break;
  398. case TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA:
  399. return "TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA";
  400. break;
  401. case TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA:
  402. return "TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA";
  403. break;
  404. case TLS_ECDH_RSA_WITH_NULL_SHA:
  405. return "TLS_ECDH_RSA_WITH_NULL_SHA";
  406. break;
  407. case TLS_ECDH_RSA_WITH_RC4_128_SHA:
  408. return "TLS_ECDH_RSA_WITH_RC4_128_SHA";
  409. break;
  410. case TLS_ECDH_RSA_WITH_3DES_EDE_CBC_SHA:
  411. return "TLS_ECDH_RSA_WITH_3DES_EDE_CBC_SHA";
  412. break;
  413. case TLS_ECDH_RSA_WITH_AES_128_CBC_SHA:
  414. return "TLS_ECDH_RSA_WITH_AES_128_CBC_SHA";
  415. break;
  416. case TLS_ECDH_RSA_WITH_AES_256_CBC_SHA:
  417. return "TLS_ECDH_RSA_WITH_AES_256_CBC_SHA";
  418. break;
  419. case TLS_ECDHE_RSA_WITH_NULL_SHA:
  420. return "TLS_ECDHE_RSA_WITH_NULL_SHA";
  421. break;
  422. case TLS_ECDHE_RSA_WITH_RC4_128_SHA:
  423. return "TLS_ECDHE_RSA_WITH_RC4_128_SHA";
  424. break;
  425. case TLS_ECDHE_RSA_WITH_3DES_EDE_CBC_SHA:
  426. return "TLS_ECDHE_RSA_WITH_3DES_EDE_CBC_SHA";
  427. break;
  428. case TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA:
  429. return "TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA";
  430. break;
  431. case TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA:
  432. return "TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA";
  433. break;
  434. case TLS_ECDH_anon_WITH_NULL_SHA:
  435. return "TLS_ECDH_anon_WITH_NULL_SHA";
  436. break;
  437. case TLS_ECDH_anon_WITH_RC4_128_SHA:
  438. return "TLS_ECDH_anon_WITH_RC4_128_SHA";
  439. break;
  440. case TLS_ECDH_anon_WITH_3DES_EDE_CBC_SHA:
  441. return "TLS_ECDH_anon_WITH_3DES_EDE_CBC_SHA";
  442. break;
  443. case TLS_ECDH_anon_WITH_AES_128_CBC_SHA:
  444. return "TLS_ECDH_anon_WITH_AES_128_CBC_SHA";
  445. break;
  446. case TLS_ECDH_anon_WITH_AES_256_CBC_SHA:
  447. return "TLS_ECDH_anon_WITH_AES_256_CBC_SHA";
  448. break;
  449. #endif /* CURL_BUILD_MAC_10_6 || CURL_BUILD_IOS */
  450. #if CURL_BUILD_MAC_10_8 || CURL_BUILD_IOS
  451. /* TLS 1.2 (RFC 5246) */
  452. case TLS_RSA_WITH_NULL_MD5:
  453. return "TLS_RSA_WITH_NULL_MD5";
  454. break;
  455. case TLS_RSA_WITH_NULL_SHA:
  456. return "TLS_RSA_WITH_NULL_SHA";
  457. break;
  458. case TLS_RSA_WITH_RC4_128_MD5:
  459. return "TLS_RSA_WITH_RC4_128_MD5";
  460. break;
  461. case TLS_RSA_WITH_RC4_128_SHA:
  462. return "TLS_RSA_WITH_RC4_128_SHA";
  463. break;
  464. case TLS_RSA_WITH_3DES_EDE_CBC_SHA:
  465. return "TLS_RSA_WITH_3DES_EDE_CBC_SHA";
  466. break;
  467. case TLS_RSA_WITH_NULL_SHA256:
  468. return "TLS_RSA_WITH_NULL_SHA256";
  469. break;
  470. case TLS_RSA_WITH_AES_128_CBC_SHA256:
  471. return "TLS_RSA_WITH_AES_128_CBC_SHA256";
  472. break;
  473. case TLS_RSA_WITH_AES_256_CBC_SHA256:
  474. return "TLS_RSA_WITH_AES_256_CBC_SHA256";
  475. break;
  476. case TLS_DH_DSS_WITH_3DES_EDE_CBC_SHA:
  477. return "TLS_DH_DSS_WITH_3DES_EDE_CBC_SHA";
  478. break;
  479. case TLS_DH_RSA_WITH_3DES_EDE_CBC_SHA:
  480. return "TLS_DH_RSA_WITH_3DES_EDE_CBC_SHA";
  481. break;
  482. case TLS_DHE_DSS_WITH_3DES_EDE_CBC_SHA:
  483. return "TLS_DHE_DSS_WITH_3DES_EDE_CBC_SHA";
  484. break;
  485. case TLS_DHE_RSA_WITH_3DES_EDE_CBC_SHA:
  486. return "TLS_DHE_RSA_WITH_3DES_EDE_CBC_SHA";
  487. break;
  488. case TLS_DH_DSS_WITH_AES_128_CBC_SHA256:
  489. return "TLS_DH_DSS_WITH_AES_128_CBC_SHA256";
  490. break;
  491. case TLS_DH_RSA_WITH_AES_128_CBC_SHA256:
  492. return "TLS_DH_RSA_WITH_AES_128_CBC_SHA256";
  493. break;
  494. case TLS_DHE_DSS_WITH_AES_128_CBC_SHA256:
  495. return "TLS_DHE_DSS_WITH_AES_128_CBC_SHA256";
  496. break;
  497. case TLS_DHE_RSA_WITH_AES_128_CBC_SHA256:
  498. return "TLS_DHE_RSA_WITH_AES_128_CBC_SHA256";
  499. break;
  500. case TLS_DH_DSS_WITH_AES_256_CBC_SHA256:
  501. return "TLS_DH_DSS_WITH_AES_256_CBC_SHA256";
  502. break;
  503. case TLS_DH_RSA_WITH_AES_256_CBC_SHA256:
  504. return "TLS_DH_RSA_WITH_AES_256_CBC_SHA256";
  505. break;
  506. case TLS_DHE_DSS_WITH_AES_256_CBC_SHA256:
  507. return "TLS_DHE_DSS_WITH_AES_256_CBC_SHA256";
  508. break;
  509. case TLS_DHE_RSA_WITH_AES_256_CBC_SHA256:
  510. return "TLS_DHE_RSA_WITH_AES_256_CBC_SHA256";
  511. break;
  512. case TLS_DH_anon_WITH_RC4_128_MD5:
  513. return "TLS_DH_anon_WITH_RC4_128_MD5";
  514. break;
  515. case TLS_DH_anon_WITH_3DES_EDE_CBC_SHA:
  516. return "TLS_DH_anon_WITH_3DES_EDE_CBC_SHA";
  517. break;
  518. case TLS_DH_anon_WITH_AES_128_CBC_SHA256:
  519. return "TLS_DH_anon_WITH_AES_128_CBC_SHA256";
  520. break;
  521. case TLS_DH_anon_WITH_AES_256_CBC_SHA256:
  522. return "TLS_DH_anon_WITH_AES_256_CBC_SHA256";
  523. break;
  524. /* TLS 1.2 with AES GCM (RFC 5288) */
  525. case TLS_RSA_WITH_AES_128_GCM_SHA256:
  526. return "TLS_RSA_WITH_AES_128_GCM_SHA256";
  527. break;
  528. case TLS_RSA_WITH_AES_256_GCM_SHA384:
  529. return "TLS_RSA_WITH_AES_256_GCM_SHA384";
  530. break;
  531. case TLS_DHE_RSA_WITH_AES_128_GCM_SHA256:
  532. return "TLS_DHE_RSA_WITH_AES_128_GCM_SHA256";
  533. break;
  534. case TLS_DHE_RSA_WITH_AES_256_GCM_SHA384:
  535. return "TLS_DHE_RSA_WITH_AES_256_GCM_SHA384";
  536. break;
  537. case TLS_DH_RSA_WITH_AES_128_GCM_SHA256:
  538. return "TLS_DH_RSA_WITH_AES_128_GCM_SHA256";
  539. break;
  540. case TLS_DH_RSA_WITH_AES_256_GCM_SHA384:
  541. return "TLS_DH_RSA_WITH_AES_256_GCM_SHA384";
  542. break;
  543. case TLS_DHE_DSS_WITH_AES_128_GCM_SHA256:
  544. return "TLS_DHE_DSS_WITH_AES_128_GCM_SHA256";
  545. break;
  546. case TLS_DHE_DSS_WITH_AES_256_GCM_SHA384:
  547. return "TLS_DHE_DSS_WITH_AES_256_GCM_SHA384";
  548. break;
  549. case TLS_DH_DSS_WITH_AES_128_GCM_SHA256:
  550. return "TLS_DH_DSS_WITH_AES_128_GCM_SHA256";
  551. break;
  552. case TLS_DH_DSS_WITH_AES_256_GCM_SHA384:
  553. return "TLS_DH_DSS_WITH_AES_256_GCM_SHA384";
  554. break;
  555. case TLS_DH_anon_WITH_AES_128_GCM_SHA256:
  556. return "TLS_DH_anon_WITH_AES_128_GCM_SHA256";
  557. break;
  558. case TLS_DH_anon_WITH_AES_256_GCM_SHA384:
  559. return "TLS_DH_anon_WITH_AES_256_GCM_SHA384";
  560. break;
  561. /* TLS 1.2 with elliptic curve ciphers (RFC 5289) */
  562. case TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256:
  563. return "TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256";
  564. break;
  565. case TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA384:
  566. return "TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA384";
  567. break;
  568. case TLS_ECDH_ECDSA_WITH_AES_128_CBC_SHA256:
  569. return "TLS_ECDH_ECDSA_WITH_AES_128_CBC_SHA256";
  570. break;
  571. case TLS_ECDH_ECDSA_WITH_AES_256_CBC_SHA384:
  572. return "TLS_ECDH_ECDSA_WITH_AES_256_CBC_SHA384";
  573. break;
  574. case TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256:
  575. return "TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256";
  576. break;
  577. case TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384:
  578. return "TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384";
  579. break;
  580. case TLS_ECDH_RSA_WITH_AES_128_CBC_SHA256:
  581. return "TLS_ECDH_RSA_WITH_AES_128_CBC_SHA256";
  582. break;
  583. case TLS_ECDH_RSA_WITH_AES_256_CBC_SHA384:
  584. return "TLS_ECDH_RSA_WITH_AES_256_CBC_SHA384";
  585. break;
  586. case TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256:
  587. return "TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256";
  588. break;
  589. case TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384:
  590. return "TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384";
  591. break;
  592. case TLS_ECDH_ECDSA_WITH_AES_128_GCM_SHA256:
  593. return "TLS_ECDH_ECDSA_WITH_AES_128_GCM_SHA256";
  594. break;
  595. case TLS_ECDH_ECDSA_WITH_AES_256_GCM_SHA384:
  596. return "TLS_ECDH_ECDSA_WITH_AES_256_GCM_SHA384";
  597. break;
  598. case TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256:
  599. return "TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256";
  600. break;
  601. case TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384:
  602. return "TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384";
  603. break;
  604. case TLS_ECDH_RSA_WITH_AES_128_GCM_SHA256:
  605. return "TLS_ECDH_RSA_WITH_AES_128_GCM_SHA256";
  606. break;
  607. case TLS_ECDH_RSA_WITH_AES_256_GCM_SHA384:
  608. return "TLS_ECDH_RSA_WITH_AES_256_GCM_SHA384";
  609. break;
  610. case TLS_EMPTY_RENEGOTIATION_INFO_SCSV:
  611. return "TLS_EMPTY_RENEGOTIATION_INFO_SCSV";
  612. break;
  613. #else
  614. case SSL_RSA_WITH_NULL_MD5:
  615. return "TLS_RSA_WITH_NULL_MD5";
  616. break;
  617. case SSL_RSA_WITH_NULL_SHA:
  618. return "TLS_RSA_WITH_NULL_SHA";
  619. break;
  620. case SSL_RSA_WITH_RC4_128_MD5:
  621. return "TLS_RSA_WITH_RC4_128_MD5";
  622. break;
  623. case SSL_RSA_WITH_RC4_128_SHA:
  624. return "TLS_RSA_WITH_RC4_128_SHA";
  625. break;
  626. case SSL_RSA_WITH_3DES_EDE_CBC_SHA:
  627. return "TLS_RSA_WITH_3DES_EDE_CBC_SHA";
  628. break;
  629. case SSL_DH_anon_WITH_RC4_128_MD5:
  630. return "TLS_DH_anon_WITH_RC4_128_MD5";
  631. break;
  632. case SSL_DH_anon_WITH_3DES_EDE_CBC_SHA:
  633. return "TLS_DH_anon_WITH_3DES_EDE_CBC_SHA";
  634. break;
  635. #endif /* CURL_BUILD_MAC_10_8 || CURL_BUILD_IOS */
  636. }
  637. return "TLS_NULL_WITH_NULL_NULL";
  638. }
  639. #if CURL_BUILD_MAC
  640. CF_INLINE void GetDarwinVersionNumber(int *major, int *minor)
  641. {
  642. int mib[2];
  643. char *os_version;
  644. size_t os_version_len;
  645. char *os_version_major, *os_version_minor/*, *os_version_point*/;
  646. /* Get the Darwin kernel version from the kernel using sysctl(): */
  647. mib[0] = CTL_KERN;
  648. mib[1] = KERN_OSRELEASE;
  649. if(sysctl(mib, 2, NULL, &os_version_len, NULL, 0) == -1)
  650. return;
  651. os_version = malloc(os_version_len*sizeof(char));
  652. if(!os_version)
  653. return;
  654. if(sysctl(mib, 2, os_version, &os_version_len, NULL, 0) == -1) {
  655. free(os_version);
  656. return;
  657. }
  658. /* Parse the version: */
  659. os_version_major = strtok(os_version, ".");
  660. os_version_minor = strtok(NULL, ".");
  661. /*os_version_point = strtok(NULL, ".");*/
  662. *major = atoi(os_version_major);
  663. *minor = atoi(os_version_minor);
  664. free(os_version);
  665. }
  666. #endif /* CURL_BUILD_MAC */
  667. /* Apple provides a myriad of ways of getting information about a certificate
  668. into a string. Some aren't available under iOS or newer cats. So here's
  669. a unified function for getting a string describing the certificate that
  670. ought to work in all cats starting with Leopard. */
  671. CF_INLINE CFStringRef CopyCertSubject(SecCertificateRef cert)
  672. {
  673. CFStringRef server_cert_summary = CFSTR("(null)");
  674. #if CURL_BUILD_IOS
  675. /* iOS: There's only one way to do this. */
  676. server_cert_summary = SecCertificateCopySubjectSummary(cert);
  677. #else
  678. #if CURL_BUILD_MAC_10_7
  679. /* Lion & later: Get the long description if we can. */
  680. if(SecCertificateCopyLongDescription != NULL)
  681. server_cert_summary =
  682. SecCertificateCopyLongDescription(NULL, cert, NULL);
  683. else
  684. #endif /* CURL_BUILD_MAC_10_7 */
  685. #if CURL_BUILD_MAC_10_6
  686. /* Snow Leopard: Get the certificate summary. */
  687. if(SecCertificateCopySubjectSummary != NULL)
  688. server_cert_summary = SecCertificateCopySubjectSummary(cert);
  689. else
  690. #endif /* CURL_BUILD_MAC_10_6 */
  691. /* Leopard is as far back as we go... */
  692. (void)SecCertificateCopyCommonName(cert, &server_cert_summary);
  693. #endif /* CURL_BUILD_IOS */
  694. return server_cert_summary;
  695. }
  696. #if CURL_SUPPORT_MAC_10_7
  697. /* The SecKeychainSearch API was deprecated in Lion, and using it will raise
  698. deprecation warnings, so let's not compile this unless it's necessary: */
  699. static OSStatus CopyIdentityWithLabelOldSchool(char *label,
  700. SecIdentityRef *out_c_a_k)
  701. {
  702. OSStatus status = errSecItemNotFound;
  703. SecKeychainAttributeList attr_list;
  704. SecKeychainAttribute attr;
  705. SecKeychainSearchRef search = NULL;
  706. SecCertificateRef cert = NULL;
  707. /* Set up the attribute list: */
  708. attr_list.count = 1L;
  709. attr_list.attr = &attr;
  710. /* Set up our lone search criterion: */
  711. attr.tag = kSecLabelItemAttr;
  712. attr.data = label;
  713. attr.length = (UInt32)strlen(label);
  714. /* Start searching: */
  715. status = SecKeychainSearchCreateFromAttributes(NULL,
  716. kSecCertificateItemClass,
  717. &attr_list,
  718. &search);
  719. if(status == noErr) {
  720. status = SecKeychainSearchCopyNext(search,
  721. (SecKeychainItemRef *)&cert);
  722. if(status == noErr && cert) {
  723. /* If we found a certificate, does it have a private key? */
  724. status = SecIdentityCreateWithCertificate(NULL, cert, out_c_a_k);
  725. CFRelease(cert);
  726. }
  727. }
  728. if(search)
  729. CFRelease(search);
  730. return status;
  731. }
  732. #endif /* CURL_SUPPORT_MAC_10_7 */
  733. static OSStatus CopyIdentityWithLabel(char *label,
  734. SecIdentityRef *out_cert_and_key)
  735. {
  736. OSStatus status = errSecItemNotFound;
  737. #if CURL_BUILD_MAC_10_7 || CURL_BUILD_IOS
  738. /* SecItemCopyMatching() was introduced in iOS and Snow Leopard.
  739. kSecClassIdentity was introduced in Lion. If both exist, let's use them
  740. to find the certificate. */
  741. if(SecItemCopyMatching != NULL && kSecClassIdentity != NULL) {
  742. CFTypeRef keys[4];
  743. CFTypeRef values[4];
  744. CFDictionaryRef query_dict;
  745. CFStringRef label_cf = CFStringCreateWithCString(NULL, label,
  746. kCFStringEncodingUTF8);
  747. /* Set up our search criteria and expected results: */
  748. values[0] = kSecClassIdentity; /* we want a certificate and a key */
  749. keys[0] = kSecClass;
  750. values[1] = kCFBooleanTrue; /* we want a reference */
  751. keys[1] = kSecReturnRef;
  752. values[2] = kSecMatchLimitOne; /* one is enough, thanks */
  753. keys[2] = kSecMatchLimit;
  754. /* identity searches need a SecPolicyRef in order to work */
  755. values[3] = SecPolicyCreateSSL(false, label_cf);
  756. keys[3] = kSecMatchPolicy;
  757. query_dict = CFDictionaryCreate(NULL, (const void **)keys,
  758. (const void **)values, 4L,
  759. &kCFCopyStringDictionaryKeyCallBacks,
  760. &kCFTypeDictionaryValueCallBacks);
  761. CFRelease(values[3]);
  762. CFRelease(label_cf);
  763. /* Do we have a match? */
  764. status = SecItemCopyMatching(query_dict, (CFTypeRef *)out_cert_and_key);
  765. CFRelease(query_dict);
  766. }
  767. else {
  768. #if CURL_SUPPORT_MAC_10_7
  769. /* On Leopard and Snow Leopard, fall back to SecKeychainSearch. */
  770. status = CopyIdentityWithLabelOldSchool(label, out_cert_and_key);
  771. #endif /* CURL_SUPPORT_MAC_10_7 */
  772. }
  773. #elif CURL_SUPPORT_MAC_10_7
  774. /* For developers building on older cats, we have no choice but to fall back
  775. to SecKeychainSearch. */
  776. status = CopyIdentityWithLabelOldSchool(label, out_cert_and_key);
  777. #endif /* CURL_BUILD_MAC_10_7 || CURL_BUILD_IOS */
  778. return status;
  779. }
  780. static CURLcode darwinssl_connect_step1(struct connectdata *conn,
  781. int sockindex)
  782. {
  783. struct SessionHandle *data = conn->data;
  784. curl_socket_t sockfd = conn->sock[sockindex];
  785. struct ssl_connect_data *connssl = &conn->ssl[sockindex];
  786. #ifdef ENABLE_IPV6
  787. struct in6_addr addr;
  788. #else
  789. struct in_addr addr;
  790. #endif /* ENABLE_IPV6 */
  791. size_t all_ciphers_count = 0UL, allowed_ciphers_count = 0UL, i;
  792. SSLCipherSuite *all_ciphers = NULL, *allowed_ciphers = NULL;
  793. char *ssl_sessionid;
  794. size_t ssl_sessionid_len;
  795. OSStatus err = noErr;
  796. #if CURL_BUILD_MAC
  797. int darwinver_maj = 0, darwinver_min = 0;
  798. GetDarwinVersionNumber(&darwinver_maj, &darwinver_min);
  799. #endif /* CURL_BUILD_MAC */
  800. #if CURL_BUILD_MAC_10_8 || CURL_BUILD_IOS
  801. if(SSLCreateContext != NULL) { /* use the newer API if avaialble */
  802. if(connssl->ssl_ctx)
  803. CFRelease(connssl->ssl_ctx);
  804. connssl->ssl_ctx = SSLCreateContext(NULL, kSSLClientSide, kSSLStreamType);
  805. if(!connssl->ssl_ctx) {
  806. failf(data, "SSL: couldn't create a context!");
  807. return CURLE_OUT_OF_MEMORY;
  808. }
  809. }
  810. else {
  811. /* The old ST API does not exist under iOS, so don't compile it: */
  812. #if CURL_SUPPORT_MAC_10_8
  813. if(connssl->ssl_ctx)
  814. (void)SSLDisposeContext(connssl->ssl_ctx);
  815. err = SSLNewContext(false, &(connssl->ssl_ctx));
  816. if(err != noErr) {
  817. failf(data, "SSL: couldn't create a context: OSStatus %d", err);
  818. return CURLE_OUT_OF_MEMORY;
  819. }
  820. #endif /* CURL_SUPPORT_MAC_10_8 */
  821. }
  822. #else
  823. if(connssl->ssl_ctx)
  824. (void)SSLDisposeContext(connssl->ssl_ctx);
  825. err = SSLNewContext(false, &(connssl->ssl_ctx));
  826. if(err != noErr) {
  827. failf(data, "SSL: couldn't create a context: OSStatus %d", err);
  828. return CURLE_OUT_OF_MEMORY;
  829. }
  830. #endif /* CURL_BUILD_MAC_10_8 || CURL_BUILD_IOS */
  831. connssl->ssl_write_buffered_length = 0UL; /* reset buffered write length */
  832. /* check to see if we've been told to use an explicit SSL/TLS version */
  833. #if CURL_BUILD_MAC_10_8 || CURL_BUILD_IOS
  834. if(SSLSetProtocolVersionMax != NULL) {
  835. switch(data->set.ssl.version) {
  836. case CURL_SSLVERSION_DEFAULT: default:
  837. (void)SSLSetProtocolVersionMin(connssl->ssl_ctx, kSSLProtocol3);
  838. (void)SSLSetProtocolVersionMax(connssl->ssl_ctx, kTLSProtocol12);
  839. break;
  840. case CURL_SSLVERSION_TLSv1:
  841. (void)SSLSetProtocolVersionMin(connssl->ssl_ctx, kTLSProtocol1);
  842. (void)SSLSetProtocolVersionMax(connssl->ssl_ctx, kTLSProtocol12);
  843. break;
  844. case CURL_SSLVERSION_SSLv3:
  845. (void)SSLSetProtocolVersionMin(connssl->ssl_ctx, kSSLProtocol3);
  846. (void)SSLSetProtocolVersionMax(connssl->ssl_ctx, kSSLProtocol3);
  847. break;
  848. case CURL_SSLVERSION_SSLv2:
  849. err = SSLSetProtocolVersionMin(connssl->ssl_ctx, kSSLProtocol2);
  850. if(err != noErr) {
  851. failf(data, "Your version of the OS does not support SSLv2");
  852. return CURLE_SSL_CONNECT_ERROR;
  853. }
  854. (void)SSLSetProtocolVersionMax(connssl->ssl_ctx, kSSLProtocol2);
  855. }
  856. }
  857. else {
  858. #if CURL_SUPPORT_MAC_10_8
  859. (void)SSLSetProtocolVersionEnabled(connssl->ssl_ctx,
  860. kSSLProtocolAll,
  861. false);
  862. switch (data->set.ssl.version) {
  863. case CURL_SSLVERSION_DEFAULT: default:
  864. (void)SSLSetProtocolVersionEnabled(connssl->ssl_ctx,
  865. kSSLProtocol3,
  866. true);
  867. (void)SSLSetProtocolVersionEnabled(connssl->ssl_ctx,
  868. kTLSProtocol1,
  869. true);
  870. (void)SSLSetProtocolVersionEnabled(connssl->ssl_ctx,
  871. kTLSProtocol11,
  872. true);
  873. (void)SSLSetProtocolVersionEnabled(connssl->ssl_ctx,
  874. kTLSProtocol12,
  875. true);
  876. break;
  877. case CURL_SSLVERSION_TLSv1:
  878. (void)SSLSetProtocolVersionEnabled(connssl->ssl_ctx,
  879. kTLSProtocol1,
  880. true);
  881. (void)SSLSetProtocolVersionEnabled(connssl->ssl_ctx,
  882. kTLSProtocol11,
  883. true);
  884. (void)SSLSetProtocolVersionEnabled(connssl->ssl_ctx,
  885. kTLSProtocol12,
  886. true);
  887. break;
  888. case CURL_SSLVERSION_SSLv3:
  889. (void)SSLSetProtocolVersionEnabled(connssl->ssl_ctx,
  890. kSSLProtocol3,
  891. true);
  892. break;
  893. case CURL_SSLVERSION_SSLv2:
  894. err = SSLSetProtocolVersionEnabled(connssl->ssl_ctx,
  895. kSSLProtocol2,
  896. true);
  897. if(err != noErr) {
  898. failf(data, "Your version of the OS does not support SSLv2");
  899. return CURLE_SSL_CONNECT_ERROR;
  900. }
  901. break;
  902. }
  903. #endif /* CURL_SUPPORT_MAC_10_8 */
  904. }
  905. #else
  906. (void)SSLSetProtocolVersionEnabled(connssl->ssl_ctx, kSSLProtocolAll, false);
  907. switch(data->set.ssl.version) {
  908. default:
  909. case CURL_SSLVERSION_DEFAULT:
  910. (void)SSLSetProtocolVersionEnabled(connssl->ssl_ctx,
  911. kSSLProtocol3,
  912. true);
  913. (void)SSLSetProtocolVersionEnabled(connssl->ssl_ctx,
  914. kTLSProtocol1,
  915. true);
  916. break;
  917. case CURL_SSLVERSION_TLSv1:
  918. (void)SSLSetProtocolVersionEnabled(connssl->ssl_ctx,
  919. kTLSProtocol1,
  920. true);
  921. break;
  922. case CURL_SSLVERSION_SSLv2:
  923. err = SSLSetProtocolVersionEnabled(connssl->ssl_ctx,
  924. kSSLProtocol2,
  925. true);
  926. if(err != noErr) {
  927. failf(data, "Your version of the OS does not support SSLv2");
  928. return CURLE_SSL_CONNECT_ERROR;
  929. }
  930. break;
  931. case CURL_SSLVERSION_SSLv3:
  932. (void)SSLSetProtocolVersionEnabled(connssl->ssl_ctx,
  933. kSSLProtocol3,
  934. true);
  935. break;
  936. }
  937. #endif /* CURL_BUILD_MAC_10_8 || CURL_BUILD_IOS */
  938. if(data->set.str[STRING_KEY]) {
  939. infof(data, "WARNING: SSL: CURLOPT_SSLKEY is ignored by Secure "
  940. "Transport. The private key must be in the Keychain.\n");
  941. }
  942. if(data->set.str[STRING_CERT]) {
  943. SecIdentityRef cert_and_key = NULL;
  944. /* User wants to authenticate with a client cert. Look for it: */
  945. err = CopyIdentityWithLabel(data->set.str[STRING_CERT], &cert_and_key);
  946. if(err == noErr) {
  947. SecCertificateRef cert = NULL;
  948. CFTypeRef certs_c[1];
  949. CFArrayRef certs;
  950. /* If we found one, print it out: */
  951. err = SecIdentityCopyCertificate(cert_and_key, &cert);
  952. if(err == noErr) {
  953. CFStringRef cert_summary = CopyCertSubject(cert);
  954. char cert_summary_c[128];
  955. if(cert_summary) {
  956. memset(cert_summary_c, 0, 128);
  957. if(CFStringGetCString(cert_summary,
  958. cert_summary_c,
  959. 128,
  960. kCFStringEncodingUTF8)) {
  961. infof(data, "Client certificate: %s\n", cert_summary_c);
  962. }
  963. CFRelease(cert_summary);
  964. CFRelease(cert);
  965. }
  966. }
  967. certs_c[0] = cert_and_key;
  968. certs = CFArrayCreate(NULL, (const void **)certs_c, 1L,
  969. &kCFTypeArrayCallBacks);
  970. err = SSLSetCertificate(connssl->ssl_ctx, certs);
  971. if(certs)
  972. CFRelease(certs);
  973. if(err != noErr) {
  974. failf(data, "SSL: SSLSetCertificate() failed: OSStatus %d", err);
  975. return CURLE_SSL_CERTPROBLEM;
  976. }
  977. CFRelease(cert_and_key);
  978. }
  979. else {
  980. failf(data, "SSL: Can't find the certificate \"%s\" and its private key "
  981. "in the Keychain.", data->set.str[STRING_CERT]);
  982. return CURLE_SSL_CERTPROBLEM;
  983. }
  984. }
  985. /* SSL always tries to verify the peer, this only says whether it should
  986. * fail to connect if the verification fails, or if it should continue
  987. * anyway. In the latter case the result of the verification is checked with
  988. * SSL_get_verify_result() below. */
  989. #if CURL_BUILD_MAC_10_6 || CURL_BUILD_IOS
  990. /* Snow Leopard introduced the SSLSetSessionOption() function, but due to
  991. a library bug with the way the kSSLSessionOptionBreakOnServerAuth flag
  992. works, it doesn't work as expected under Snow Leopard or Lion.
  993. So we need to call SSLSetEnableCertVerify() on those older cats in order
  994. to disable certificate validation if the user turned that off.
  995. (SecureTransport will always validate the certificate chain by
  996. default.) */
  997. /* (Note: Darwin 12.x.x is Mountain Lion.) */
  998. #if CURL_BUILD_MAC
  999. if(SSLSetSessionOption != NULL && darwinver_maj >= 12) {
  1000. #else
  1001. if(SSLSetSessionOption != NULL) {
  1002. #endif /* CURL_BUILD_MAC */
  1003. err = SSLSetSessionOption(connssl->ssl_ctx,
  1004. kSSLSessionOptionBreakOnServerAuth,
  1005. data->set.ssl.verifypeer?false:true);
  1006. if(err != noErr) {
  1007. failf(data, "SSL: SSLSetSessionOption() failed: OSStatus %d", err);
  1008. return CURLE_SSL_CONNECT_ERROR;
  1009. }
  1010. }
  1011. else {
  1012. #if CURL_SUPPORT_MAC_10_8
  1013. err = SSLSetEnableCertVerify(connssl->ssl_ctx,
  1014. data->set.ssl.verifypeer?true:false);
  1015. if(err != noErr) {
  1016. failf(data, "SSL: SSLSetEnableCertVerify() failed: OSStatus %d", err);
  1017. return CURLE_SSL_CONNECT_ERROR;
  1018. }
  1019. #endif /* CURL_SUPPORT_MAC_10_8 */
  1020. }
  1021. #else
  1022. err = SSLSetEnableCertVerify(connssl->ssl_ctx,
  1023. data->set.ssl.verifypeer?true:false);
  1024. if(err != noErr) {
  1025. failf(data, "SSL: SSLSetEnableCertVerify() failed: OSStatus %d", err);
  1026. return CURLE_SSL_CONNECT_ERROR;
  1027. }
  1028. #endif /* CURL_BUILD_MAC_10_6 || CURL_BUILD_IOS */
  1029. /* If this is a domain name and not an IP address, then configure SNI.
  1030. * Also: the verifyhost setting influences SNI usage */
  1031. /* If this is a domain name and not an IP address, then configure SNI: */
  1032. if((0 == Curl_inet_pton(AF_INET, conn->host.name, &addr)) &&
  1033. #ifdef ENABLE_IPV6
  1034. (0 == Curl_inet_pton(AF_INET6, conn->host.name, &addr)) &&
  1035. #endif
  1036. data->set.ssl.verifyhost) {
  1037. err = SSLSetPeerDomainName(connssl->ssl_ctx, conn->host.name,
  1038. strlen(conn->host.name));
  1039. if(err != noErr) {
  1040. infof(data, "WARNING: SSL: SSLSetPeerDomainName() failed: OSStatus %d\n",
  1041. err);
  1042. }
  1043. }
  1044. /* Disable cipher suites that ST supports but are not safe. These ciphers
  1045. are unlikely to be used in any case since ST gives other ciphers a much
  1046. higher priority, but it's probably better that we not connect at all than
  1047. to give the user a false sense of security if the server only supports
  1048. insecure ciphers. (Note: We don't care about SSLv2-only ciphers.) */
  1049. (void)SSLGetNumberSupportedCiphers(connssl->ssl_ctx, &all_ciphers_count);
  1050. all_ciphers = malloc(all_ciphers_count*sizeof(SSLCipherSuite));
  1051. allowed_ciphers = malloc(all_ciphers_count*sizeof(SSLCipherSuite));
  1052. if(all_ciphers && allowed_ciphers &&
  1053. SSLGetSupportedCiphers(connssl->ssl_ctx, all_ciphers,
  1054. &all_ciphers_count) == noErr) {
  1055. for(i = 0UL ; i < all_ciphers_count ; i++) {
  1056. #if CURL_BUILD_MAC
  1057. /* There's a known bug in early versions of Mountain Lion where ST's ECC
  1058. ciphers (cipher suite 0xC001 through 0xC032) simply do not work.
  1059. Work around the problem here by disabling those ciphers if we are
  1060. running in an affected version of OS X. */
  1061. if(darwinver_maj == 12 && darwinver_min <= 3 &&
  1062. all_ciphers[i] >= 0xC001 && all_ciphers[i] <= 0xC032) {
  1063. continue;
  1064. }
  1065. #endif /* CURL_BUILD_MAC */
  1066. switch(all_ciphers[i]) {
  1067. /* Disable NULL ciphersuites: */
  1068. case SSL_NULL_WITH_NULL_NULL:
  1069. case SSL_RSA_WITH_NULL_MD5:
  1070. case SSL_RSA_WITH_NULL_SHA:
  1071. case SSL_FORTEZZA_DMS_WITH_NULL_SHA:
  1072. case 0xC001: /* TLS_ECDH_ECDSA_WITH_NULL_SHA */
  1073. case 0xC006: /* TLS_ECDHE_ECDSA_WITH_NULL_SHA */
  1074. case 0xC00B: /* TLS_ECDH_RSA_WITH_NULL_SHA */
  1075. case 0xC010: /* TLS_ECDHE_RSA_WITH_NULL_SHA */
  1076. /* Disable anonymous ciphersuites: */
  1077. case SSL_DH_anon_EXPORT_WITH_RC4_40_MD5:
  1078. case SSL_DH_anon_WITH_RC4_128_MD5:
  1079. case SSL_DH_anon_EXPORT_WITH_DES40_CBC_SHA:
  1080. case SSL_DH_anon_WITH_DES_CBC_SHA:
  1081. case SSL_DH_anon_WITH_3DES_EDE_CBC_SHA:
  1082. case TLS_DH_anon_WITH_AES_128_CBC_SHA:
  1083. case TLS_DH_anon_WITH_AES_256_CBC_SHA:
  1084. case 0xC015: /* TLS_ECDH_anon_WITH_NULL_SHA */
  1085. case 0xC016: /* TLS_ECDH_anon_WITH_RC4_128_SHA */
  1086. case 0xC017: /* TLS_ECDH_anon_WITH_3DES_EDE_CBC_SHA */
  1087. case 0xC018: /* TLS_ECDH_anon_WITH_AES_128_CBC_SHA */
  1088. case 0xC019: /* TLS_ECDH_anon_WITH_AES_256_CBC_SHA */
  1089. case 0x006C: /* TLS_DH_anon_WITH_AES_128_CBC_SHA256 */
  1090. case 0x006D: /* TLS_DH_anon_WITH_AES_256_CBC_SHA256 */
  1091. case 0x00A6: /* TLS_DH_anon_WITH_AES_128_GCM_SHA256 */
  1092. case 0x00A7: /* TLS_DH_anon_WITH_AES_256_GCM_SHA384 */
  1093. /* Disable weak key ciphersuites: */
  1094. case SSL_RSA_EXPORT_WITH_RC4_40_MD5:
  1095. case SSL_RSA_EXPORT_WITH_RC2_CBC_40_MD5:
  1096. case SSL_RSA_EXPORT_WITH_DES40_CBC_SHA:
  1097. case SSL_DH_DSS_EXPORT_WITH_DES40_CBC_SHA:
  1098. case SSL_DH_RSA_EXPORT_WITH_DES40_CBC_SHA:
  1099. case SSL_DHE_DSS_EXPORT_WITH_DES40_CBC_SHA:
  1100. case SSL_DHE_RSA_EXPORT_WITH_DES40_CBC_SHA:
  1101. case SSL_RSA_WITH_DES_CBC_SHA:
  1102. case SSL_DH_DSS_WITH_DES_CBC_SHA:
  1103. case SSL_DH_RSA_WITH_DES_CBC_SHA:
  1104. case SSL_DHE_DSS_WITH_DES_CBC_SHA:
  1105. case SSL_DHE_RSA_WITH_DES_CBC_SHA:
  1106. /* Disable IDEA: */
  1107. case SSL_RSA_WITH_IDEA_CBC_SHA:
  1108. case SSL_RSA_WITH_IDEA_CBC_MD5:
  1109. break;
  1110. default: /* enable everything else */
  1111. allowed_ciphers[allowed_ciphers_count++] = all_ciphers[i];
  1112. break;
  1113. }
  1114. }
  1115. err = SSLSetEnabledCiphers(connssl->ssl_ctx, allowed_ciphers,
  1116. allowed_ciphers_count);
  1117. if(err != noErr) {
  1118. failf(data, "SSL: SSLSetEnabledCiphers() failed: OSStatus %d", err);
  1119. return CURLE_SSL_CONNECT_ERROR;
  1120. }
  1121. }
  1122. else {
  1123. Curl_safefree(all_ciphers);
  1124. Curl_safefree(allowed_ciphers);
  1125. failf(data, "SSL: Failed to allocate memory for allowed ciphers");
  1126. return CURLE_OUT_OF_MEMORY;
  1127. }
  1128. Curl_safefree(all_ciphers);
  1129. Curl_safefree(allowed_ciphers);
  1130. /* Check if there's a cached ID we can/should use here! */
  1131. if(!Curl_ssl_getsessionid(conn, (void **)&ssl_sessionid,
  1132. &ssl_sessionid_len)) {
  1133. /* we got a session id, use it! */
  1134. err = SSLSetPeerID(connssl->ssl_ctx, ssl_sessionid, ssl_sessionid_len);
  1135. if(err != noErr) {
  1136. failf(data, "SSL: SSLSetPeerID() failed: OSStatus %d", err);
  1137. return CURLE_SSL_CONNECT_ERROR;
  1138. }
  1139. /* Informational message */
  1140. infof(data, "SSL re-using session ID\n");
  1141. }
  1142. /* If there isn't one, then let's make one up! This has to be done prior
  1143. to starting the handshake. */
  1144. else {
  1145. CURLcode retcode;
  1146. ssl_sessionid = malloc(256*sizeof(char));
  1147. ssl_sessionid_len = snprintf(ssl_sessionid, 256, "curl:%s:%hu",
  1148. conn->host.name, conn->remote_port);
  1149. err = SSLSetPeerID(connssl->ssl_ctx, ssl_sessionid, ssl_sessionid_len);
  1150. if(err != noErr) {
  1151. failf(data, "SSL: SSLSetPeerID() failed: OSStatus %d", err);
  1152. return CURLE_SSL_CONNECT_ERROR;
  1153. }
  1154. retcode = Curl_ssl_addsessionid(conn, ssl_sessionid, ssl_sessionid_len);
  1155. if(retcode!= CURLE_OK) {
  1156. failf(data, "failed to store ssl session");
  1157. return retcode;
  1158. }
  1159. }
  1160. err = SSLSetIOFuncs(connssl->ssl_ctx, SocketRead, SocketWrite);
  1161. if(err != noErr) {
  1162. failf(data, "SSL: SSLSetIOFuncs() failed: OSStatus %d", err);
  1163. return CURLE_SSL_CONNECT_ERROR;
  1164. }
  1165. /* pass the raw socket into the SSL layers */
  1166. /* We need to store the FD in a constant memory address, because
  1167. * SSLSetConnection() will not copy that address. I've found that
  1168. * conn->sock[sockindex] may change on its own. */
  1169. connssl->ssl_sockfd = sockfd;
  1170. err = SSLSetConnection(connssl->ssl_ctx, connssl);
  1171. if(err != noErr) {
  1172. failf(data, "SSL: SSLSetConnection() failed: %d", err);
  1173. return CURLE_SSL_CONNECT_ERROR;
  1174. }
  1175. connssl->connecting_state = ssl_connect_2;
  1176. return CURLE_OK;
  1177. }
  1178. static CURLcode
  1179. darwinssl_connect_step2(struct connectdata *conn, int sockindex)
  1180. {
  1181. struct SessionHandle *data = conn->data;
  1182. struct ssl_connect_data *connssl = &conn->ssl[sockindex];
  1183. OSStatus err;
  1184. SSLCipherSuite cipher;
  1185. SSLProtocol protocol = 0;
  1186. DEBUGASSERT(ssl_connect_2 == connssl->connecting_state
  1187. || ssl_connect_2_reading == connssl->connecting_state
  1188. || ssl_connect_2_writing == connssl->connecting_state);
  1189. /* Here goes nothing: */
  1190. err = SSLHandshake(connssl->ssl_ctx);
  1191. if(err != noErr) {
  1192. switch (err) {
  1193. case errSSLWouldBlock: /* they're not done with us yet */
  1194. connssl->connecting_state = connssl->ssl_direction ?
  1195. ssl_connect_2_writing : ssl_connect_2_reading;
  1196. return CURLE_OK;
  1197. /* The below is errSSLServerAuthCompleted; it's not defined in
  1198. Leopard's headers */
  1199. case -9841:
  1200. /* the documentation says we need to call SSLHandshake() again */
  1201. return darwinssl_connect_step2(conn, sockindex);
  1202. /* These are all certificate problems with the server: */
  1203. case errSSLXCertChainInvalid:
  1204. failf(data, "SSL certificate problem: Invalid certificate chain");
  1205. return CURLE_SSL_CACERT;
  1206. case errSSLUnknownRootCert:
  1207. failf(data, "SSL certificate problem: Untrusted root certificate");
  1208. return CURLE_SSL_CACERT;
  1209. case errSSLNoRootCert:
  1210. failf(data, "SSL certificate problem: No root certificate");
  1211. return CURLE_SSL_CACERT;
  1212. case errSSLCertExpired:
  1213. failf(data, "SSL certificate problem: Certificate chain had an "
  1214. "expired certificate");
  1215. return CURLE_SSL_CACERT;
  1216. case errSSLBadCert:
  1217. failf(data, "SSL certificate problem: Couldn't understand the server "
  1218. "certificate format");
  1219. return CURLE_SSL_CONNECT_ERROR;
  1220. /* These are all certificate problems with the client: */
  1221. case errSecAuthFailed:
  1222. failf(data, "SSL authentication failed");
  1223. return CURLE_SSL_CONNECT_ERROR;
  1224. case errSSLPeerHandshakeFail:
  1225. failf(data, "SSL peer handshake failed, the server most likely "
  1226. "requires a client certificate to connect");
  1227. return CURLE_SSL_CONNECT_ERROR;
  1228. case errSSLPeerUnknownCA:
  1229. failf(data, "SSL server rejected the client certificate due to "
  1230. "the certificate being signed by an unknown certificate "
  1231. "authority");
  1232. return CURLE_SSL_CONNECT_ERROR;
  1233. /* This error is raised if the server's cert didn't match the server's
  1234. host name: */
  1235. case errSSLHostNameMismatch:
  1236. failf(data, "SSL certificate peer verification failed, the "
  1237. "certificate did not match \"%s\"\n", conn->host.dispname);
  1238. return CURLE_PEER_FAILED_VERIFICATION;
  1239. /* Generic handshake errors: */
  1240. case errSSLConnectionRefused:
  1241. failf(data, "Server dropped the connection during the SSL handshake");
  1242. return CURLE_SSL_CONNECT_ERROR;
  1243. case errSSLClosedAbort:
  1244. failf(data, "Server aborted the SSL handshake");
  1245. return CURLE_SSL_CONNECT_ERROR;
  1246. case errSSLNegotiation:
  1247. failf(data, "Could not negotiate an SSL cipher suite with the server");
  1248. return CURLE_SSL_CONNECT_ERROR;
  1249. /* Sometimes paramErr happens with buggy ciphers: */
  1250. case paramErr: case errSSLInternal:
  1251. failf(data, "Internal SSL engine error encountered during the "
  1252. "SSL handshake");
  1253. return CURLE_SSL_CONNECT_ERROR;
  1254. case errSSLFatalAlert:
  1255. failf(data, "Fatal SSL engine error encountered during the SSL "
  1256. "handshake");
  1257. return CURLE_SSL_CONNECT_ERROR;
  1258. default:
  1259. failf(data, "Unknown SSL protocol error in connection to %s:%d",
  1260. conn->host.name, err);
  1261. return CURLE_SSL_CONNECT_ERROR;
  1262. }
  1263. }
  1264. else {
  1265. /* we have been connected fine, we're not waiting for anything else. */
  1266. connssl->connecting_state = ssl_connect_3;
  1267. /* Informational message */
  1268. (void)SSLGetNegotiatedCipher(connssl->ssl_ctx, &cipher);
  1269. (void)SSLGetNegotiatedProtocolVersion(connssl->ssl_ctx, &protocol);
  1270. switch (protocol) {
  1271. case kSSLProtocol2:
  1272. infof(data, "SSL 2.0 connection using %s\n",
  1273. SSLCipherNameForNumber(cipher));
  1274. break;
  1275. case kSSLProtocol3:
  1276. infof(data, "SSL 3.0 connection using %s\n",
  1277. SSLCipherNameForNumber(cipher));
  1278. break;
  1279. case kTLSProtocol1:
  1280. infof(data, "TLS 1.0 connection using %s\n",
  1281. TLSCipherNameForNumber(cipher));
  1282. break;
  1283. #if CURL_BUILD_MAC_10_8 || CURL_BUILD_IOS
  1284. case kTLSProtocol11:
  1285. infof(data, "TLS 1.1 connection using %s\n",
  1286. TLSCipherNameForNumber(cipher));
  1287. break;
  1288. case kTLSProtocol12:
  1289. infof(data, "TLS 1.2 connection using %s\n",
  1290. TLSCipherNameForNumber(cipher));
  1291. break;
  1292. #endif
  1293. default:
  1294. infof(data, "Unknown protocol connection\n");
  1295. break;
  1296. }
  1297. return CURLE_OK;
  1298. }
  1299. }
  1300. static CURLcode
  1301. darwinssl_connect_step3(struct connectdata *conn,
  1302. int sockindex)
  1303. {
  1304. struct SessionHandle *data = conn->data;
  1305. struct ssl_connect_data *connssl = &conn->ssl[sockindex];
  1306. CFStringRef server_cert_summary;
  1307. char server_cert_summary_c[128];
  1308. CFArrayRef server_certs = NULL;
  1309. SecCertificateRef server_cert;
  1310. OSStatus err;
  1311. CFIndex i, count;
  1312. SecTrustRef trust = NULL;
  1313. /* There is no step 3!
  1314. * Well, okay, if verbose mode is on, let's print the details of the
  1315. * server certificates. */
  1316. #if CURL_BUILD_MAC_10_7 || CURL_BUILD_IOS
  1317. #if CURL_BUILD_IOS
  1318. #pragma unused(server_certs)
  1319. err = SSLCopyPeerTrust(connssl->ssl_ctx, &trust);
  1320. /* For some reason, SSLCopyPeerTrust() can return noErr and yet return
  1321. a null trust, so be on guard for that: */
  1322. if(err == noErr && trust) {
  1323. count = SecTrustGetCertificateCount(trust);
  1324. for(i = 0L ; i < count ; i++) {
  1325. server_cert = SecTrustGetCertificateAtIndex(trust, i);
  1326. server_cert_summary = CopyCertSubject(server_cert);
  1327. memset(server_cert_summary_c, 0, 128);
  1328. if(CFStringGetCString(server_cert_summary,
  1329. server_cert_summary_c,
  1330. 128,
  1331. kCFStringEncodingUTF8)) {
  1332. infof(data, "Server certificate: %s\n", server_cert_summary_c);
  1333. }
  1334. CFRelease(server_cert_summary);
  1335. }
  1336. CFRelease(trust);
  1337. }
  1338. #else
  1339. /* SSLCopyPeerCertificates() is deprecated as of Mountain Lion.
  1340. The function SecTrustGetCertificateAtIndex() is officially present
  1341. in Lion, but it is unfortunately also present in Snow Leopard as
  1342. private API and doesn't work as expected. So we have to look for
  1343. a different symbol to make sure this code is only executed under
  1344. Lion or later. */
  1345. if(SecTrustEvaluateAsync != NULL) {
  1346. #pragma unused(server_certs)
  1347. err = SSLCopyPeerTrust(connssl->ssl_ctx, &trust);
  1348. /* For some reason, SSLCopyPeerTrust() can return noErr and yet return
  1349. a null trust, so be on guard for that: */
  1350. if(err == noErr && trust) {
  1351. count = SecTrustGetCertificateCount(trust);
  1352. for(i = 0L ; i < count ; i++) {
  1353. server_cert = SecTrustGetCertificateAtIndex(trust, i);
  1354. server_cert_summary = CopyCertSubject(server_cert);
  1355. memset(server_cert_summary_c, 0, 128);
  1356. if(CFStringGetCString(server_cert_summary,
  1357. server_cert_summary_c,
  1358. 128,
  1359. kCFStringEncodingUTF8)) {
  1360. infof(data, "Server certificate: %s\n", server_cert_summary_c);
  1361. }
  1362. CFRelease(server_cert_summary);
  1363. }
  1364. CFRelease(trust);
  1365. }
  1366. }
  1367. else {
  1368. #if CURL_SUPPORT_MAC_10_8
  1369. err = SSLCopyPeerCertificates(connssl->ssl_ctx, &server_certs);
  1370. /* Just in case SSLCopyPeerCertificates() returns null too... */
  1371. if(err == noErr && server_certs) {
  1372. count = CFArrayGetCount(server_certs);
  1373. for(i = 0L ; i < count ; i++) {
  1374. server_cert = (SecCertificateRef)CFArrayGetValueAtIndex(server_certs,
  1375. i);
  1376. server_cert_summary = CopyCertSubject(server_cert);
  1377. memset(server_cert_summary_c, 0, 128);
  1378. if(CFStringGetCString(server_cert_summary,
  1379. server_cert_summary_c,
  1380. 128,
  1381. kCFStringEncodingUTF8)) {
  1382. infof(data, "Server certificate: %s\n", server_cert_summary_c);
  1383. }
  1384. CFRelease(server_cert_summary);
  1385. }
  1386. CFRelease(server_certs);
  1387. }
  1388. #endif /* CURL_SUPPORT_MAC_10_8 */
  1389. }
  1390. #endif /* CURL_BUILD_IOS */
  1391. #else
  1392. #pragma unused(trust)
  1393. err = SSLCopyPeerCertificates(connssl->ssl_ctx, &server_certs);
  1394. if(err == noErr) {
  1395. count = CFArrayGetCount(server_certs);
  1396. for(i = 0L ; i < count ; i++) {
  1397. server_cert = (SecCertificateRef)CFArrayGetValueAtIndex(server_certs, i);
  1398. server_cert_summary = CopyCertSubject(server_cert);
  1399. memset(server_cert_summary_c, 0, 128);
  1400. if(CFStringGetCString(server_cert_summary,
  1401. server_cert_summary_c,
  1402. 128,
  1403. kCFStringEncodingUTF8)) {
  1404. infof(data, "Server certificate: %s\n", server_cert_summary_c);
  1405. }
  1406. CFRelease(server_cert_summary);
  1407. }
  1408. CFRelease(server_certs);
  1409. }
  1410. #endif /* CURL_BUILD_MAC_10_7 || CURL_BUILD_IOS */
  1411. connssl->connecting_state = ssl_connect_done;
  1412. return CURLE_OK;
  1413. }
  1414. static Curl_recv darwinssl_recv;
  1415. static Curl_send darwinssl_send;
  1416. static CURLcode
  1417. darwinssl_connect_common(struct connectdata *conn,
  1418. int sockindex,
  1419. bool nonblocking,
  1420. bool *done)
  1421. {
  1422. CURLcode retcode;
  1423. struct SessionHandle *data = conn->data;
  1424. struct ssl_connect_data *connssl = &conn->ssl[sockindex];
  1425. curl_socket_t sockfd = conn->sock[sockindex];
  1426. long timeout_ms;
  1427. int what;
  1428. /* check if the connection has already been established */
  1429. if(ssl_connection_complete == connssl->state) {
  1430. *done = TRUE;
  1431. return CURLE_OK;
  1432. }
  1433. if(ssl_connect_1==connssl->connecting_state) {
  1434. /* Find out how much more time we're allowed */
  1435. timeout_ms = Curl_timeleft(data, NULL, TRUE);
  1436. if(timeout_ms < 0) {
  1437. /* no need to continue if time already is up */
  1438. failf(data, "SSL connection timeout");
  1439. return CURLE_OPERATION_TIMEDOUT;
  1440. }
  1441. retcode = darwinssl_connect_step1(conn, sockindex);
  1442. if(retcode)
  1443. return retcode;
  1444. }
  1445. while(ssl_connect_2 == connssl->connecting_state ||
  1446. ssl_connect_2_reading == connssl->connecting_state ||
  1447. ssl_connect_2_writing == connssl->connecting_state) {
  1448. /* check allowed time left */
  1449. timeout_ms = Curl_timeleft(data, NULL, TRUE);
  1450. if(timeout_ms < 0) {
  1451. /* no need to continue if time already is up */
  1452. failf(data, "SSL connection timeout");
  1453. return CURLE_OPERATION_TIMEDOUT;
  1454. }
  1455. /* if ssl is expecting something, check if it's available. */
  1456. if(connssl->connecting_state == ssl_connect_2_reading
  1457. || connssl->connecting_state == ssl_connect_2_writing) {
  1458. curl_socket_t writefd = ssl_connect_2_writing ==
  1459. connssl->connecting_state?sockfd:CURL_SOCKET_BAD;
  1460. curl_socket_t readfd = ssl_connect_2_reading ==
  1461. connssl->connecting_state?sockfd:CURL_SOCKET_BAD;
  1462. what = Curl_socket_ready(readfd, writefd, nonblocking?0:timeout_ms);
  1463. if(what < 0) {
  1464. /* fatal error */
  1465. failf(data, "select/poll on SSL socket, errno: %d", SOCKERRNO);
  1466. return CURLE_SSL_CONNECT_ERROR;
  1467. }
  1468. else if(0 == what) {
  1469. if(nonblocking) {
  1470. *done = FALSE;
  1471. return CURLE_OK;
  1472. }
  1473. else {
  1474. /* timeout */
  1475. failf(data, "SSL connection timeout");
  1476. return CURLE_OPERATION_TIMEDOUT;
  1477. }
  1478. }
  1479. /* socket is readable or writable */
  1480. }
  1481. /* Run transaction, and return to the caller if it failed or if this
  1482. * connection is done nonblocking and this loop would execute again. This
  1483. * permits the owner of a multi handle to abort a connection attempt
  1484. * before step2 has completed while ensuring that a client using select()
  1485. * or epoll() will always have a valid fdset to wait on.
  1486. */
  1487. retcode = darwinssl_connect_step2(conn, sockindex);
  1488. if(retcode || (nonblocking &&
  1489. (ssl_connect_2 == connssl->connecting_state ||
  1490. ssl_connect_2_reading == connssl->connecting_state ||
  1491. ssl_connect_2_writing == connssl->connecting_state)))
  1492. return retcode;
  1493. } /* repeat step2 until all transactions are done. */
  1494. if(ssl_connect_3==connssl->connecting_state) {
  1495. retcode = darwinssl_connect_step3(conn, sockindex);
  1496. if(retcode)
  1497. return retcode;
  1498. }
  1499. if(ssl_connect_done==connssl->connecting_state) {
  1500. connssl->state = ssl_connection_complete;
  1501. conn->recv[sockindex] = darwinssl_recv;
  1502. conn->send[sockindex] = darwinssl_send;
  1503. *done = TRUE;
  1504. }
  1505. else
  1506. *done = FALSE;
  1507. /* Reset our connect state machine */
  1508. connssl->connecting_state = ssl_connect_1;
  1509. return CURLE_OK;
  1510. }
  1511. CURLcode
  1512. Curl_darwinssl_connect_nonblocking(struct connectdata *conn,
  1513. int sockindex,
  1514. bool *done)
  1515. {
  1516. return darwinssl_connect_common(conn, sockindex, TRUE, done);
  1517. }
  1518. CURLcode
  1519. Curl_darwinssl_connect(struct connectdata *conn,
  1520. int sockindex)
  1521. {
  1522. CURLcode retcode;
  1523. bool done = FALSE;
  1524. retcode = darwinssl_connect_common(conn, sockindex, FALSE, &done);
  1525. if(retcode)
  1526. return retcode;
  1527. DEBUGASSERT(done);
  1528. return CURLE_OK;
  1529. }
  1530. void Curl_darwinssl_close(struct connectdata *conn, int sockindex)
  1531. {
  1532. struct ssl_connect_data *connssl = &conn->ssl[sockindex];
  1533. if(connssl->ssl_ctx) {
  1534. (void)SSLClose(connssl->ssl_ctx);
  1535. #if CURL_BUILD_MAC_10_8 || CURL_BUILD_IOS
  1536. if(SSLCreateContext != NULL)
  1537. CFRelease(connssl->ssl_ctx);
  1538. #if CURL_SUPPORT_MAC_10_8
  1539. else
  1540. (void)SSLDisposeContext(connssl->ssl_ctx);
  1541. #endif /* CURL_SUPPORT_MAC_10_8 */
  1542. #else
  1543. (void)SSLDisposeContext(connssl->ssl_ctx);
  1544. #endif /* CURL_BUILD_MAC_10_8 || CURL_BUILD_IOS */
  1545. connssl->ssl_ctx = NULL;
  1546. }
  1547. connssl->ssl_sockfd = 0;
  1548. }
  1549. void Curl_darwinssl_close_all(struct SessionHandle *data)
  1550. {
  1551. /* SecureTransport doesn't separate sessions from contexts, so... */
  1552. (void)data;
  1553. }
  1554. int Curl_darwinssl_shutdown(struct connectdata *conn, int sockindex)
  1555. {
  1556. struct ssl_connect_data *connssl = &conn->ssl[sockindex];
  1557. struct SessionHandle *data = conn->data;
  1558. ssize_t nread;
  1559. int what;
  1560. int rc;
  1561. char buf[120];
  1562. if(!connssl->ssl_ctx)
  1563. return 0;
  1564. if(data->set.ftp_ccc != CURLFTPSSL_CCC_ACTIVE)
  1565. return 0;
  1566. Curl_darwinssl_close(conn, sockindex);
  1567. rc = 0;
  1568. what = Curl_socket_ready(conn->sock[sockindex],
  1569. CURL_SOCKET_BAD, SSL_SHUTDOWN_TIMEOUT);
  1570. for(;;) {
  1571. if(what < 0) {
  1572. /* anything that gets here is fatally bad */
  1573. failf(data, "select/poll on SSL socket, errno: %d", SOCKERRNO);
  1574. rc = -1;
  1575. break;
  1576. }
  1577. if(!what) { /* timeout */
  1578. failf(data, "SSL shutdown timeout");
  1579. break;
  1580. }
  1581. /* Something to read, let's do it and hope that it is the close
  1582. notify alert from the server. No way to SSL_Read now, so use read(). */
  1583. nread = read(conn->sock[sockindex], buf, sizeof(buf));
  1584. if(nread < 0) {
  1585. failf(data, "read: %s", strerror(errno));
  1586. rc = -1;
  1587. }
  1588. if(nread <= 0)
  1589. break;
  1590. what = Curl_socket_ready(conn->sock[sockindex], CURL_SOCKET_BAD, 0);
  1591. }
  1592. return rc;
  1593. }
  1594. void Curl_darwinssl_session_free(void *ptr)
  1595. {
  1596. /* ST, as of iOS 5 and Mountain Lion, has no public method of deleting a
  1597. cached session ID inside the Security framework. There is a private
  1598. function that does this, but I don't want to have to explain to you why I
  1599. got your application rejected from the App Store due to the use of a
  1600. private API, so the best we can do is free up our own char array that we
  1601. created way back in darwinssl_connect_step1... */
  1602. Curl_safefree(ptr);
  1603. }
  1604. size_t Curl_darwinssl_version(char *buffer, size_t size)
  1605. {
  1606. return snprintf(buffer, size, "SecureTransport");
  1607. }
  1608. /*
  1609. * This function uses SSLGetSessionState to determine connection status.
  1610. *
  1611. * Return codes:
  1612. * 1 means the connection is still in place
  1613. * 0 means the connection has been closed
  1614. * -1 means the connection status is unknown
  1615. */
  1616. int Curl_darwinssl_check_cxn(struct connectdata *conn)
  1617. {
  1618. struct ssl_connect_data *connssl = &conn->ssl[FIRSTSOCKET];
  1619. OSStatus err;
  1620. SSLSessionState state;
  1621. if(connssl->ssl_ctx) {
  1622. err = SSLGetSessionState(connssl->ssl_ctx, &state);
  1623. if(err == noErr)
  1624. return state == kSSLConnected || state == kSSLHandshake;
  1625. return -1;
  1626. }
  1627. return 0;
  1628. }
  1629. bool Curl_darwinssl_data_pending(const struct connectdata *conn,
  1630. int connindex)
  1631. {
  1632. const struct ssl_connect_data *connssl = &conn->ssl[connindex];
  1633. OSStatus err;
  1634. size_t buffer;
  1635. if(connssl->ssl_ctx) { /* SSL is in use */
  1636. err = SSLGetBufferedReadSize(connssl->ssl_ctx, &buffer);
  1637. if(err == noErr)
  1638. return buffer > 0UL;
  1639. return false;
  1640. }
  1641. else
  1642. return false;
  1643. }
  1644. void Curl_darwinssl_random(struct SessionHandle *data,
  1645. unsigned char *entropy,
  1646. size_t length)
  1647. {
  1648. /* arc4random_buf() isn't available on cats older than Lion, so let's
  1649. do this manually for the benefit of the older cats. */
  1650. size_t i;
  1651. u_int32_t random_number = 0;
  1652. for(i = 0 ; i < length ; i++) {
  1653. if(i % sizeof(u_int32_t) == 0)
  1654. random_number = arc4random();
  1655. entropy[i] = random_number & 0xFF;
  1656. random_number >>= 8;
  1657. }
  1658. i = random_number = 0;
  1659. (void)data;
  1660. }
  1661. void Curl_darwinssl_md5sum(unsigned char *tmp, /* input */
  1662. size_t tmplen,
  1663. unsigned char *md5sum, /* output */
  1664. size_t md5len)
  1665. {
  1666. (void)md5len;
  1667. (void)CC_MD5(tmp, (CC_LONG)tmplen, md5sum);
  1668. }
  1669. static ssize_t darwinssl_send(struct connectdata *conn,
  1670. int sockindex,
  1671. const void *mem,
  1672. size_t len,
  1673. CURLcode *curlcode)
  1674. {
  1675. /*struct SessionHandle *data = conn->data;*/
  1676. struct ssl_connect_data *connssl = &conn->ssl[sockindex];
  1677. size_t processed = 0UL;
  1678. OSStatus err;
  1679. /* The SSLWrite() function works a little differently than expected. The
  1680. fourth argument (processed) is currently documented in Apple's
  1681. documentation as: "On return, the length, in bytes, of the data actually
  1682. written."
  1683. Now, one could interpret that as "written to the socket," but actually,
  1684. it returns the amount of data that was written to a buffer internal to
  1685. the SSLContextRef instead. So it's possible for SSLWrite() to return
  1686. errSSLWouldBlock and a number of bytes "written" because those bytes were
  1687. encrypted and written to a buffer, not to the socket.
  1688. So if this happens, then we need to keep calling SSLWrite() over and
  1689. over again with no new data until it quits returning errSSLWouldBlock. */
  1690. /* Do we have buffered data to write from the last time we were called? */
  1691. if(connssl->ssl_write_buffered_length) {
  1692. /* Write the buffered data: */
  1693. err = SSLWrite(connssl->ssl_ctx, NULL, 0UL, &processed);
  1694. switch (err) {
  1695. case noErr:
  1696. /* processed is always going to be 0 because we didn't write to
  1697. the buffer, so return how much was written to the socket */
  1698. processed = connssl->ssl_write_buffered_length;
  1699. connssl->ssl_write_buffered_length = 0UL;
  1700. break;
  1701. case errSSLWouldBlock: /* argh, try again */
  1702. *curlcode = CURLE_AGAIN;
  1703. return -1L;
  1704. default:
  1705. failf(conn->data, "SSLWrite() returned error %d", err);
  1706. *curlcode = CURLE_SEND_ERROR;
  1707. return -1L;
  1708. }
  1709. }
  1710. else {
  1711. /* We've got new data to write: */
  1712. err = SSLWrite(connssl->ssl_ctx, mem, len, &processed);
  1713. if(err != noErr) {
  1714. switch (err) {
  1715. case errSSLWouldBlock:
  1716. /* Data was buffered but not sent, we have to tell the caller
  1717. to try sending again, and remember how much was buffered */
  1718. connssl->ssl_write_buffered_length = len;
  1719. *curlcode = CURLE_AGAIN;
  1720. return -1L;
  1721. default:
  1722. failf(conn->data, "SSLWrite() returned error %d", err);
  1723. *curlcode = CURLE_SEND_ERROR;
  1724. return -1L;
  1725. }
  1726. }
  1727. }
  1728. return (ssize_t)processed;
  1729. }
  1730. static ssize_t darwinssl_recv(struct connectdata *conn,
  1731. int num,
  1732. char *buf,
  1733. size_t buffersize,
  1734. CURLcode *curlcode)
  1735. {
  1736. /*struct SessionHandle *data = conn->data;*/
  1737. struct ssl_connect_data *connssl = &conn->ssl[num];
  1738. size_t processed = 0UL;
  1739. OSStatus err = SSLRead(connssl->ssl_ctx, buf, buffersize, &processed);
  1740. if(err != noErr) {
  1741. switch (err) {
  1742. case errSSLWouldBlock: /* return how much we read (if anything) */
  1743. if(processed)
  1744. return (ssize_t)processed;
  1745. *curlcode = CURLE_AGAIN;
  1746. return -1L;
  1747. break;
  1748. /* errSSLClosedGraceful - server gracefully shut down the SSL session
  1749. errSSLClosedNoNotify - server hung up on us instead of sending a
  1750. closure alert notice, read() is returning 0
  1751. Either way, inform the caller that the server disconnected. */
  1752. case errSSLClosedGraceful:
  1753. case errSSLClosedNoNotify:
  1754. *curlcode = CURLE_OK;
  1755. return -1L;
  1756. break;
  1757. default:
  1758. failf(conn->data, "SSLRead() return error %d", err);
  1759. *curlcode = CURLE_RECV_ERROR;
  1760. return -1L;
  1761. break;
  1762. }
  1763. }
  1764. return (ssize_t)processed;
  1765. }
  1766. #endif /* USE_DARWINSSL */