darwinssl.c 104 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129
  1. /***************************************************************************
  2. * _ _ ____ _
  3. * Project ___| | | | _ \| |
  4. * / __| | | | |_) | |
  5. * | (__| |_| | _ <| |___
  6. * \___|\___/|_| \_\_____|
  7. *
  8. * Copyright (C) 2012 - 2017, Nick Zitzmann, <nickzman@gmail.com>.
  9. * Copyright (C) 2012 - 2018, 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 https://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 macOS SecureTransport-specific code for the
  25. * TLS/SSL layer. No code but vtls.c should ever call or use these functions.
  26. */
  27. #include "curl_setup.h"
  28. #include "urldata.h" /* for the Curl_easy definition */
  29. #include "curl_base64.h"
  30. #include "strtok.h"
  31. #ifdef USE_DARWINSSL
  32. #ifdef __clang__
  33. #pragma clang diagnostic push
  34. #pragma clang diagnostic ignored "-Wtautological-pointer-compare"
  35. #endif /* __clang__ */
  36. #include <limits.h>
  37. #include <Security/Security.h>
  38. /* For some reason, when building for iOS, the omnibus header above does
  39. * not include SecureTransport.h as of iOS SDK 5.1. */
  40. #include <Security/SecureTransport.h>
  41. #include <CoreFoundation/CoreFoundation.h>
  42. #include <CommonCrypto/CommonDigest.h>
  43. /* The Security framework has changed greatly between iOS and different macOS
  44. versions, and we will try to support as many of them as we can (back to
  45. Leopard and iOS 5) by using macros and weak-linking.
  46. In general, you want to build this using the most recent OS SDK, since some
  47. features require curl to be built against the latest SDK. TLS 1.1 and 1.2
  48. support, for instance, require the macOS 10.8 SDK or later. TLS 1.3
  49. requires the macOS 10.13 or iOS 11 SDK or later. */
  50. #if (TARGET_OS_MAC && !(TARGET_OS_EMBEDDED || TARGET_OS_IPHONE))
  51. #if MAC_OS_X_VERSION_MAX_ALLOWED < 1050
  52. #error "The darwinssl back-end requires Leopard or later."
  53. #endif /* MAC_OS_X_VERSION_MAX_ALLOWED < 1050 */
  54. #define CURL_BUILD_IOS 0
  55. #define CURL_BUILD_IOS_7 0
  56. #define CURL_BUILD_IOS_11 0
  57. #define CURL_BUILD_MAC 1
  58. /* This is the maximum API level we are allowed to use when building: */
  59. #define CURL_BUILD_MAC_10_5 MAC_OS_X_VERSION_MAX_ALLOWED >= 1050
  60. #define CURL_BUILD_MAC_10_6 MAC_OS_X_VERSION_MAX_ALLOWED >= 1060
  61. #define CURL_BUILD_MAC_10_7 MAC_OS_X_VERSION_MAX_ALLOWED >= 1070
  62. #define CURL_BUILD_MAC_10_8 MAC_OS_X_VERSION_MAX_ALLOWED >= 1080
  63. #define CURL_BUILD_MAC_10_9 MAC_OS_X_VERSION_MAX_ALLOWED >= 1090
  64. #define CURL_BUILD_MAC_10_13 MAC_OS_X_VERSION_MAX_ALLOWED >= 101300
  65. /* These macros mean "the following code is present to allow runtime backward
  66. compatibility with at least this cat or earlier":
  67. (You set this at build-time using the compiler command line option
  68. "-mmacos-version-min.") */
  69. #define CURL_SUPPORT_MAC_10_5 MAC_OS_X_VERSION_MIN_REQUIRED <= 1050
  70. #define CURL_SUPPORT_MAC_10_6 MAC_OS_X_VERSION_MIN_REQUIRED <= 1060
  71. #define CURL_SUPPORT_MAC_10_7 MAC_OS_X_VERSION_MIN_REQUIRED <= 1070
  72. #define CURL_SUPPORT_MAC_10_8 MAC_OS_X_VERSION_MIN_REQUIRED <= 1080
  73. #define CURL_SUPPORT_MAC_10_9 MAC_OS_X_VERSION_MIN_REQUIRED <= 1090
  74. #elif TARGET_OS_EMBEDDED || TARGET_OS_IPHONE
  75. #define CURL_BUILD_IOS 1
  76. #define CURL_BUILD_IOS_7 __IPHONE_OS_VERSION_MAX_ALLOWED >= 70000
  77. #define CURL_BUILD_IOS_11 __IPHONE_OS_VERSION_MAX_ALLOWED >= 110000
  78. #define CURL_BUILD_MAC 0
  79. #define CURL_BUILD_MAC_10_5 0
  80. #define CURL_BUILD_MAC_10_6 0
  81. #define CURL_BUILD_MAC_10_7 0
  82. #define CURL_BUILD_MAC_10_8 0
  83. #define CURL_BUILD_MAC_10_9 0
  84. #define CURL_BUILD_MAC_10_13 0
  85. #define CURL_SUPPORT_MAC_10_5 0
  86. #define CURL_SUPPORT_MAC_10_6 0
  87. #define CURL_SUPPORT_MAC_10_7 0
  88. #define CURL_SUPPORT_MAC_10_8 0
  89. #define CURL_SUPPORT_MAC_10_9 0
  90. #else
  91. #error "The darwinssl back-end requires iOS or OS X."
  92. #endif /* (TARGET_OS_MAC && !(TARGET_OS_EMBEDDED || TARGET_OS_IPHONE)) */
  93. #if CURL_BUILD_MAC
  94. #include <sys/sysctl.h>
  95. #endif /* CURL_BUILD_MAC */
  96. #include "urldata.h"
  97. #include "sendf.h"
  98. #include "inet_pton.h"
  99. #include "connect.h"
  100. #include "select.h"
  101. #include "vtls.h"
  102. #include "darwinssl.h"
  103. #include "curl_printf.h"
  104. #include "curl_memory.h"
  105. /* The last #include file should be: */
  106. #include "memdebug.h"
  107. /* From MacTypes.h (which we can't include because it isn't present in iOS: */
  108. #define ioErr -36
  109. #define paramErr -50
  110. struct ssl_backend_data {
  111. SSLContextRef ssl_ctx;
  112. curl_socket_t ssl_sockfd;
  113. bool ssl_direction; /* true if writing, false if reading */
  114. size_t ssl_write_buffered_length;
  115. };
  116. #define BACKEND connssl->backend
  117. /* pinned public key support tests */
  118. /* version 1 supports macOS 10.12+ and iOS 10+ */
  119. #if ((TARGET_OS_IPHONE && __IPHONE_OS_VERSION_MIN_REQUIRED >= 100000) || \
  120. (!TARGET_OS_IPHONE && __MAC_OS_X_VERSION_MIN_REQUIRED >= 101200))
  121. #define DARWIN_SSL_PINNEDPUBKEY_V1 1
  122. #endif
  123. /* version 2 supports MacOSX 10.7+ */
  124. #if (!TARGET_OS_IPHONE && __MAC_OS_X_VERSION_MIN_REQUIRED >= 1070)
  125. #define DARWIN_SSL_PINNEDPUBKEY_V2 1
  126. #endif
  127. #if defined(DARWIN_SSL_PINNEDPUBKEY_V1) || defined(DARWIN_SSL_PINNEDPUBKEY_V2)
  128. /* this backend supports CURLOPT_PINNEDPUBLICKEY */
  129. #define DARWIN_SSL_PINNEDPUBKEY 1
  130. #endif /* DARWIN_SSL_PINNEDPUBKEY */
  131. #ifdef DARWIN_SSL_PINNEDPUBKEY
  132. /* both new and old APIs return rsa keys missing the spki header (not DER) */
  133. static const unsigned char rsa4096SpkiHeader[] = {
  134. 0x30, 0x82, 0x02, 0x22, 0x30, 0x0d,
  135. 0x06, 0x09, 0x2a, 0x86, 0x48, 0x86,
  136. 0xf7, 0x0d, 0x01, 0x01, 0x01, 0x05,
  137. 0x00, 0x03, 0x82, 0x02, 0x0f, 0x00};
  138. static const unsigned char rsa2048SpkiHeader[] = {
  139. 0x30, 0x82, 0x01, 0x22, 0x30, 0x0d,
  140. 0x06, 0x09, 0x2a, 0x86, 0x48, 0x86,
  141. 0xf7, 0x0d, 0x01, 0x01, 0x01, 0x05,
  142. 0x00, 0x03, 0x82, 0x01, 0x0f, 0x00};
  143. #ifdef DARWIN_SSL_PINNEDPUBKEY_V1
  144. /* the *new* version doesn't return DER encoded ecdsa certs like the old... */
  145. static const unsigned char ecDsaSecp256r1SpkiHeader[] = {
  146. 0x30, 0x59, 0x30, 0x13, 0x06, 0x07,
  147. 0x2a, 0x86, 0x48, 0xce, 0x3d, 0x02,
  148. 0x01, 0x06, 0x08, 0x2a, 0x86, 0x48,
  149. 0xce, 0x3d, 0x03, 0x01, 0x07, 0x03,
  150. 0x42, 0x00};
  151. static const unsigned char ecDsaSecp384r1SpkiHeader[] = {
  152. 0x30, 0x76, 0x30, 0x10, 0x06, 0x07,
  153. 0x2a, 0x86, 0x48, 0xce, 0x3d, 0x02,
  154. 0x01, 0x06, 0x05, 0x2b, 0x81, 0x04,
  155. 0x00, 0x22, 0x03, 0x62, 0x00};
  156. #endif /* DARWIN_SSL_PINNEDPUBKEY_V1 */
  157. #endif /* DARWIN_SSL_PINNEDPUBKEY */
  158. /* The following two functions were ripped from Apple sample code,
  159. * with some modifications: */
  160. static OSStatus SocketRead(SSLConnectionRef connection,
  161. void *data, /* owned by
  162. * caller, data
  163. * RETURNED */
  164. size_t *dataLength) /* IN/OUT */
  165. {
  166. size_t bytesToGo = *dataLength;
  167. size_t initLen = bytesToGo;
  168. UInt8 *currData = (UInt8 *)data;
  169. /*int sock = *(int *)connection;*/
  170. struct ssl_connect_data *connssl = (struct ssl_connect_data *)connection;
  171. int sock = BACKEND->ssl_sockfd;
  172. OSStatus rtn = noErr;
  173. size_t bytesRead;
  174. ssize_t rrtn;
  175. int theErr;
  176. *dataLength = 0;
  177. for(;;) {
  178. bytesRead = 0;
  179. rrtn = read(sock, currData, bytesToGo);
  180. if(rrtn <= 0) {
  181. /* this is guesswork... */
  182. theErr = errno;
  183. if(rrtn == 0) { /* EOF = server hung up */
  184. /* the framework will turn this into errSSLClosedNoNotify */
  185. rtn = errSSLClosedGraceful;
  186. }
  187. else /* do the switch */
  188. switch(theErr) {
  189. case ENOENT:
  190. /* connection closed */
  191. rtn = errSSLClosedGraceful;
  192. break;
  193. case ECONNRESET:
  194. rtn = errSSLClosedAbort;
  195. break;
  196. case EAGAIN:
  197. rtn = errSSLWouldBlock;
  198. BACKEND->ssl_direction = false;
  199. break;
  200. default:
  201. rtn = ioErr;
  202. break;
  203. }
  204. break;
  205. }
  206. else {
  207. bytesRead = rrtn;
  208. }
  209. bytesToGo -= bytesRead;
  210. currData += bytesRead;
  211. if(bytesToGo == 0) {
  212. /* filled buffer with incoming data, done */
  213. break;
  214. }
  215. }
  216. *dataLength = initLen - bytesToGo;
  217. return rtn;
  218. }
  219. static OSStatus SocketWrite(SSLConnectionRef connection,
  220. const void *data,
  221. size_t *dataLength) /* IN/OUT */
  222. {
  223. size_t bytesSent = 0;
  224. /*int sock = *(int *)connection;*/
  225. struct ssl_connect_data *connssl = (struct ssl_connect_data *)connection;
  226. int sock = BACKEND->ssl_sockfd;
  227. ssize_t length;
  228. size_t dataLen = *dataLength;
  229. const UInt8 *dataPtr = (UInt8 *)data;
  230. OSStatus ortn;
  231. int theErr;
  232. *dataLength = 0;
  233. do {
  234. length = write(sock,
  235. (char *)dataPtr + bytesSent,
  236. dataLen - bytesSent);
  237. } while((length > 0) &&
  238. ( (bytesSent += length) < dataLen) );
  239. if(length <= 0) {
  240. theErr = errno;
  241. if(theErr == EAGAIN) {
  242. ortn = errSSLWouldBlock;
  243. BACKEND->ssl_direction = true;
  244. }
  245. else {
  246. ortn = ioErr;
  247. }
  248. }
  249. else {
  250. ortn = noErr;
  251. }
  252. *dataLength = bytesSent;
  253. return ortn;
  254. }
  255. #ifndef CURL_DISABLE_VERBOSE_STRINGS
  256. CF_INLINE const char *SSLCipherNameForNumber(SSLCipherSuite cipher)
  257. {
  258. switch(cipher) {
  259. /* SSL version 3.0 */
  260. case SSL_RSA_WITH_NULL_MD5:
  261. return "SSL_RSA_WITH_NULL_MD5";
  262. break;
  263. case SSL_RSA_WITH_NULL_SHA:
  264. return "SSL_RSA_WITH_NULL_SHA";
  265. break;
  266. case SSL_RSA_EXPORT_WITH_RC4_40_MD5:
  267. return "SSL_RSA_EXPORT_WITH_RC4_40_MD5";
  268. break;
  269. case SSL_RSA_WITH_RC4_128_MD5:
  270. return "SSL_RSA_WITH_RC4_128_MD5";
  271. break;
  272. case SSL_RSA_WITH_RC4_128_SHA:
  273. return "SSL_RSA_WITH_RC4_128_SHA";
  274. break;
  275. case SSL_RSA_EXPORT_WITH_RC2_CBC_40_MD5:
  276. return "SSL_RSA_EXPORT_WITH_RC2_CBC_40_MD5";
  277. break;
  278. case SSL_RSA_WITH_IDEA_CBC_SHA:
  279. return "SSL_RSA_WITH_IDEA_CBC_SHA";
  280. break;
  281. case SSL_RSA_EXPORT_WITH_DES40_CBC_SHA:
  282. return "SSL_RSA_EXPORT_WITH_DES40_CBC_SHA";
  283. break;
  284. case SSL_RSA_WITH_DES_CBC_SHA:
  285. return "SSL_RSA_WITH_DES_CBC_SHA";
  286. break;
  287. case SSL_RSA_WITH_3DES_EDE_CBC_SHA:
  288. return "SSL_RSA_WITH_3DES_EDE_CBC_SHA";
  289. break;
  290. case SSL_DH_DSS_EXPORT_WITH_DES40_CBC_SHA:
  291. return "SSL_DH_DSS_EXPORT_WITH_DES40_CBC_SHA";
  292. break;
  293. case SSL_DH_DSS_WITH_DES_CBC_SHA:
  294. return "SSL_DH_DSS_WITH_DES_CBC_SHA";
  295. break;
  296. case SSL_DH_DSS_WITH_3DES_EDE_CBC_SHA:
  297. return "SSL_DH_DSS_WITH_3DES_EDE_CBC_SHA";
  298. break;
  299. case SSL_DH_RSA_EXPORT_WITH_DES40_CBC_SHA:
  300. return "SSL_DH_RSA_EXPORT_WITH_DES40_CBC_SHA";
  301. break;
  302. case SSL_DH_RSA_WITH_DES_CBC_SHA:
  303. return "SSL_DH_RSA_WITH_DES_CBC_SHA";
  304. break;
  305. case SSL_DH_RSA_WITH_3DES_EDE_CBC_SHA:
  306. return "SSL_DH_RSA_WITH_3DES_EDE_CBC_SHA";
  307. break;
  308. case SSL_DHE_DSS_EXPORT_WITH_DES40_CBC_SHA:
  309. return "SSL_DHE_DSS_EXPORT_WITH_DES40_CBC_SHA";
  310. break;
  311. case SSL_DHE_DSS_WITH_DES_CBC_SHA:
  312. return "SSL_DHE_DSS_WITH_DES_CBC_SHA";
  313. break;
  314. case SSL_DHE_DSS_WITH_3DES_EDE_CBC_SHA:
  315. return "SSL_DHE_DSS_WITH_3DES_EDE_CBC_SHA";
  316. break;
  317. case SSL_DHE_RSA_EXPORT_WITH_DES40_CBC_SHA:
  318. return "SSL_DHE_RSA_EXPORT_WITH_DES40_CBC_SHA";
  319. break;
  320. case SSL_DHE_RSA_WITH_DES_CBC_SHA:
  321. return "SSL_DHE_RSA_WITH_DES_CBC_SHA";
  322. break;
  323. case SSL_DHE_RSA_WITH_3DES_EDE_CBC_SHA:
  324. return "SSL_DHE_RSA_WITH_3DES_EDE_CBC_SHA";
  325. break;
  326. case SSL_DH_anon_EXPORT_WITH_RC4_40_MD5:
  327. return "SSL_DH_anon_EXPORT_WITH_RC4_40_MD5";
  328. break;
  329. case SSL_DH_anon_WITH_RC4_128_MD5:
  330. return "SSL_DH_anon_WITH_RC4_128_MD5";
  331. break;
  332. case SSL_DH_anon_EXPORT_WITH_DES40_CBC_SHA:
  333. return "SSL_DH_anon_EXPORT_WITH_DES40_CBC_SHA";
  334. break;
  335. case SSL_DH_anon_WITH_DES_CBC_SHA:
  336. return "SSL_DH_anon_WITH_DES_CBC_SHA";
  337. break;
  338. case SSL_DH_anon_WITH_3DES_EDE_CBC_SHA:
  339. return "SSL_DH_anon_WITH_3DES_EDE_CBC_SHA";
  340. break;
  341. case SSL_FORTEZZA_DMS_WITH_NULL_SHA:
  342. return "SSL_FORTEZZA_DMS_WITH_NULL_SHA";
  343. break;
  344. case SSL_FORTEZZA_DMS_WITH_FORTEZZA_CBC_SHA:
  345. return "SSL_FORTEZZA_DMS_WITH_FORTEZZA_CBC_SHA";
  346. break;
  347. /* TLS 1.0 with AES (RFC 3268)
  348. (Apparently these are used in SSLv3 implementations as well.) */
  349. case TLS_RSA_WITH_AES_128_CBC_SHA:
  350. return "TLS_RSA_WITH_AES_128_CBC_SHA";
  351. break;
  352. case TLS_DH_DSS_WITH_AES_128_CBC_SHA:
  353. return "TLS_DH_DSS_WITH_AES_128_CBC_SHA";
  354. break;
  355. case TLS_DH_RSA_WITH_AES_128_CBC_SHA:
  356. return "TLS_DH_RSA_WITH_AES_128_CBC_SHA";
  357. break;
  358. case TLS_DHE_DSS_WITH_AES_128_CBC_SHA:
  359. return "TLS_DHE_DSS_WITH_AES_128_CBC_SHA";
  360. break;
  361. case TLS_DHE_RSA_WITH_AES_128_CBC_SHA:
  362. return "TLS_DHE_RSA_WITH_AES_128_CBC_SHA";
  363. break;
  364. case TLS_DH_anon_WITH_AES_128_CBC_SHA:
  365. return "TLS_DH_anon_WITH_AES_128_CBC_SHA";
  366. break;
  367. case TLS_RSA_WITH_AES_256_CBC_SHA:
  368. return "TLS_RSA_WITH_AES_256_CBC_SHA";
  369. break;
  370. case TLS_DH_DSS_WITH_AES_256_CBC_SHA:
  371. return "TLS_DH_DSS_WITH_AES_256_CBC_SHA";
  372. break;
  373. case TLS_DH_RSA_WITH_AES_256_CBC_SHA:
  374. return "TLS_DH_RSA_WITH_AES_256_CBC_SHA";
  375. break;
  376. case TLS_DHE_DSS_WITH_AES_256_CBC_SHA:
  377. return "TLS_DHE_DSS_WITH_AES_256_CBC_SHA";
  378. break;
  379. case TLS_DHE_RSA_WITH_AES_256_CBC_SHA:
  380. return "TLS_DHE_RSA_WITH_AES_256_CBC_SHA";
  381. break;
  382. case TLS_DH_anon_WITH_AES_256_CBC_SHA:
  383. return "TLS_DH_anon_WITH_AES_256_CBC_SHA";
  384. break;
  385. /* SSL version 2.0 */
  386. case SSL_RSA_WITH_RC2_CBC_MD5:
  387. return "SSL_RSA_WITH_RC2_CBC_MD5";
  388. break;
  389. case SSL_RSA_WITH_IDEA_CBC_MD5:
  390. return "SSL_RSA_WITH_IDEA_CBC_MD5";
  391. break;
  392. case SSL_RSA_WITH_DES_CBC_MD5:
  393. return "SSL_RSA_WITH_DES_CBC_MD5";
  394. break;
  395. case SSL_RSA_WITH_3DES_EDE_CBC_MD5:
  396. return "SSL_RSA_WITH_3DES_EDE_CBC_MD5";
  397. break;
  398. }
  399. return "SSL_NULL_WITH_NULL_NULL";
  400. }
  401. CF_INLINE const char *TLSCipherNameForNumber(SSLCipherSuite cipher)
  402. {
  403. switch(cipher) {
  404. /* TLS 1.0 with AES (RFC 3268) */
  405. case TLS_RSA_WITH_AES_128_CBC_SHA:
  406. return "TLS_RSA_WITH_AES_128_CBC_SHA";
  407. break;
  408. case TLS_DH_DSS_WITH_AES_128_CBC_SHA:
  409. return "TLS_DH_DSS_WITH_AES_128_CBC_SHA";
  410. break;
  411. case TLS_DH_RSA_WITH_AES_128_CBC_SHA:
  412. return "TLS_DH_RSA_WITH_AES_128_CBC_SHA";
  413. break;
  414. case TLS_DHE_DSS_WITH_AES_128_CBC_SHA:
  415. return "TLS_DHE_DSS_WITH_AES_128_CBC_SHA";
  416. break;
  417. case TLS_DHE_RSA_WITH_AES_128_CBC_SHA:
  418. return "TLS_DHE_RSA_WITH_AES_128_CBC_SHA";
  419. break;
  420. case TLS_DH_anon_WITH_AES_128_CBC_SHA:
  421. return "TLS_DH_anon_WITH_AES_128_CBC_SHA";
  422. break;
  423. case TLS_RSA_WITH_AES_256_CBC_SHA:
  424. return "TLS_RSA_WITH_AES_256_CBC_SHA";
  425. break;
  426. case TLS_DH_DSS_WITH_AES_256_CBC_SHA:
  427. return "TLS_DH_DSS_WITH_AES_256_CBC_SHA";
  428. break;
  429. case TLS_DH_RSA_WITH_AES_256_CBC_SHA:
  430. return "TLS_DH_RSA_WITH_AES_256_CBC_SHA";
  431. break;
  432. case TLS_DHE_DSS_WITH_AES_256_CBC_SHA:
  433. return "TLS_DHE_DSS_WITH_AES_256_CBC_SHA";
  434. break;
  435. case TLS_DHE_RSA_WITH_AES_256_CBC_SHA:
  436. return "TLS_DHE_RSA_WITH_AES_256_CBC_SHA";
  437. break;
  438. case TLS_DH_anon_WITH_AES_256_CBC_SHA:
  439. return "TLS_DH_anon_WITH_AES_256_CBC_SHA";
  440. break;
  441. #if CURL_BUILD_MAC_10_6 || CURL_BUILD_IOS
  442. /* TLS 1.0 with ECDSA (RFC 4492) */
  443. case TLS_ECDH_ECDSA_WITH_NULL_SHA:
  444. return "TLS_ECDH_ECDSA_WITH_NULL_SHA";
  445. break;
  446. case TLS_ECDH_ECDSA_WITH_RC4_128_SHA:
  447. return "TLS_ECDH_ECDSA_WITH_RC4_128_SHA";
  448. break;
  449. case TLS_ECDH_ECDSA_WITH_3DES_EDE_CBC_SHA:
  450. return "TLS_ECDH_ECDSA_WITH_3DES_EDE_CBC_SHA";
  451. break;
  452. case TLS_ECDH_ECDSA_WITH_AES_128_CBC_SHA:
  453. return "TLS_ECDH_ECDSA_WITH_AES_128_CBC_SHA";
  454. break;
  455. case TLS_ECDH_ECDSA_WITH_AES_256_CBC_SHA:
  456. return "TLS_ECDH_ECDSA_WITH_AES_256_CBC_SHA";
  457. break;
  458. case TLS_ECDHE_ECDSA_WITH_NULL_SHA:
  459. return "TLS_ECDHE_ECDSA_WITH_NULL_SHA";
  460. break;
  461. case TLS_ECDHE_ECDSA_WITH_RC4_128_SHA:
  462. return "TLS_ECDHE_ECDSA_WITH_RC4_128_SHA";
  463. break;
  464. case TLS_ECDHE_ECDSA_WITH_3DES_EDE_CBC_SHA:
  465. return "TLS_ECDHE_ECDSA_WITH_3DES_EDE_CBC_SHA";
  466. break;
  467. case TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA:
  468. return "TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA";
  469. break;
  470. case TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA:
  471. return "TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA";
  472. break;
  473. case TLS_ECDH_RSA_WITH_NULL_SHA:
  474. return "TLS_ECDH_RSA_WITH_NULL_SHA";
  475. break;
  476. case TLS_ECDH_RSA_WITH_RC4_128_SHA:
  477. return "TLS_ECDH_RSA_WITH_RC4_128_SHA";
  478. break;
  479. case TLS_ECDH_RSA_WITH_3DES_EDE_CBC_SHA:
  480. return "TLS_ECDH_RSA_WITH_3DES_EDE_CBC_SHA";
  481. break;
  482. case TLS_ECDH_RSA_WITH_AES_128_CBC_SHA:
  483. return "TLS_ECDH_RSA_WITH_AES_128_CBC_SHA";
  484. break;
  485. case TLS_ECDH_RSA_WITH_AES_256_CBC_SHA:
  486. return "TLS_ECDH_RSA_WITH_AES_256_CBC_SHA";
  487. break;
  488. case TLS_ECDHE_RSA_WITH_NULL_SHA:
  489. return "TLS_ECDHE_RSA_WITH_NULL_SHA";
  490. break;
  491. case TLS_ECDHE_RSA_WITH_RC4_128_SHA:
  492. return "TLS_ECDHE_RSA_WITH_RC4_128_SHA";
  493. break;
  494. case TLS_ECDHE_RSA_WITH_3DES_EDE_CBC_SHA:
  495. return "TLS_ECDHE_RSA_WITH_3DES_EDE_CBC_SHA";
  496. break;
  497. case TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA:
  498. return "TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA";
  499. break;
  500. case TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA:
  501. return "TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA";
  502. break;
  503. case TLS_ECDH_anon_WITH_NULL_SHA:
  504. return "TLS_ECDH_anon_WITH_NULL_SHA";
  505. break;
  506. case TLS_ECDH_anon_WITH_RC4_128_SHA:
  507. return "TLS_ECDH_anon_WITH_RC4_128_SHA";
  508. break;
  509. case TLS_ECDH_anon_WITH_3DES_EDE_CBC_SHA:
  510. return "TLS_ECDH_anon_WITH_3DES_EDE_CBC_SHA";
  511. break;
  512. case TLS_ECDH_anon_WITH_AES_128_CBC_SHA:
  513. return "TLS_ECDH_anon_WITH_AES_128_CBC_SHA";
  514. break;
  515. case TLS_ECDH_anon_WITH_AES_256_CBC_SHA:
  516. return "TLS_ECDH_anon_WITH_AES_256_CBC_SHA";
  517. break;
  518. #endif /* CURL_BUILD_MAC_10_6 || CURL_BUILD_IOS */
  519. #if CURL_BUILD_MAC_10_8 || CURL_BUILD_IOS
  520. /* TLS 1.2 (RFC 5246) */
  521. case TLS_RSA_WITH_NULL_MD5:
  522. return "TLS_RSA_WITH_NULL_MD5";
  523. break;
  524. case TLS_RSA_WITH_NULL_SHA:
  525. return "TLS_RSA_WITH_NULL_SHA";
  526. break;
  527. case TLS_RSA_WITH_RC4_128_MD5:
  528. return "TLS_RSA_WITH_RC4_128_MD5";
  529. break;
  530. case TLS_RSA_WITH_RC4_128_SHA:
  531. return "TLS_RSA_WITH_RC4_128_SHA";
  532. break;
  533. case TLS_RSA_WITH_3DES_EDE_CBC_SHA:
  534. return "TLS_RSA_WITH_3DES_EDE_CBC_SHA";
  535. break;
  536. case TLS_RSA_WITH_NULL_SHA256:
  537. return "TLS_RSA_WITH_NULL_SHA256";
  538. break;
  539. case TLS_RSA_WITH_AES_128_CBC_SHA256:
  540. return "TLS_RSA_WITH_AES_128_CBC_SHA256";
  541. break;
  542. case TLS_RSA_WITH_AES_256_CBC_SHA256:
  543. return "TLS_RSA_WITH_AES_256_CBC_SHA256";
  544. break;
  545. case TLS_DH_DSS_WITH_3DES_EDE_CBC_SHA:
  546. return "TLS_DH_DSS_WITH_3DES_EDE_CBC_SHA";
  547. break;
  548. case TLS_DH_RSA_WITH_3DES_EDE_CBC_SHA:
  549. return "TLS_DH_RSA_WITH_3DES_EDE_CBC_SHA";
  550. break;
  551. case TLS_DHE_DSS_WITH_3DES_EDE_CBC_SHA:
  552. return "TLS_DHE_DSS_WITH_3DES_EDE_CBC_SHA";
  553. break;
  554. case TLS_DHE_RSA_WITH_3DES_EDE_CBC_SHA:
  555. return "TLS_DHE_RSA_WITH_3DES_EDE_CBC_SHA";
  556. break;
  557. case TLS_DH_DSS_WITH_AES_128_CBC_SHA256:
  558. return "TLS_DH_DSS_WITH_AES_128_CBC_SHA256";
  559. break;
  560. case TLS_DH_RSA_WITH_AES_128_CBC_SHA256:
  561. return "TLS_DH_RSA_WITH_AES_128_CBC_SHA256";
  562. break;
  563. case TLS_DHE_DSS_WITH_AES_128_CBC_SHA256:
  564. return "TLS_DHE_DSS_WITH_AES_128_CBC_SHA256";
  565. break;
  566. case TLS_DHE_RSA_WITH_AES_128_CBC_SHA256:
  567. return "TLS_DHE_RSA_WITH_AES_128_CBC_SHA256";
  568. break;
  569. case TLS_DH_DSS_WITH_AES_256_CBC_SHA256:
  570. return "TLS_DH_DSS_WITH_AES_256_CBC_SHA256";
  571. break;
  572. case TLS_DH_RSA_WITH_AES_256_CBC_SHA256:
  573. return "TLS_DH_RSA_WITH_AES_256_CBC_SHA256";
  574. break;
  575. case TLS_DHE_DSS_WITH_AES_256_CBC_SHA256:
  576. return "TLS_DHE_DSS_WITH_AES_256_CBC_SHA256";
  577. break;
  578. case TLS_DHE_RSA_WITH_AES_256_CBC_SHA256:
  579. return "TLS_DHE_RSA_WITH_AES_256_CBC_SHA256";
  580. break;
  581. case TLS_DH_anon_WITH_RC4_128_MD5:
  582. return "TLS_DH_anon_WITH_RC4_128_MD5";
  583. break;
  584. case TLS_DH_anon_WITH_3DES_EDE_CBC_SHA:
  585. return "TLS_DH_anon_WITH_3DES_EDE_CBC_SHA";
  586. break;
  587. case TLS_DH_anon_WITH_AES_128_CBC_SHA256:
  588. return "TLS_DH_anon_WITH_AES_128_CBC_SHA256";
  589. break;
  590. case TLS_DH_anon_WITH_AES_256_CBC_SHA256:
  591. return "TLS_DH_anon_WITH_AES_256_CBC_SHA256";
  592. break;
  593. /* TLS 1.2 with AES GCM (RFC 5288) */
  594. case TLS_RSA_WITH_AES_128_GCM_SHA256:
  595. return "TLS_RSA_WITH_AES_128_GCM_SHA256";
  596. break;
  597. case TLS_RSA_WITH_AES_256_GCM_SHA384:
  598. return "TLS_RSA_WITH_AES_256_GCM_SHA384";
  599. break;
  600. case TLS_DHE_RSA_WITH_AES_128_GCM_SHA256:
  601. return "TLS_DHE_RSA_WITH_AES_128_GCM_SHA256";
  602. break;
  603. case TLS_DHE_RSA_WITH_AES_256_GCM_SHA384:
  604. return "TLS_DHE_RSA_WITH_AES_256_GCM_SHA384";
  605. break;
  606. case TLS_DH_RSA_WITH_AES_128_GCM_SHA256:
  607. return "TLS_DH_RSA_WITH_AES_128_GCM_SHA256";
  608. break;
  609. case TLS_DH_RSA_WITH_AES_256_GCM_SHA384:
  610. return "TLS_DH_RSA_WITH_AES_256_GCM_SHA384";
  611. break;
  612. case TLS_DHE_DSS_WITH_AES_128_GCM_SHA256:
  613. return "TLS_DHE_DSS_WITH_AES_128_GCM_SHA256";
  614. break;
  615. case TLS_DHE_DSS_WITH_AES_256_GCM_SHA384:
  616. return "TLS_DHE_DSS_WITH_AES_256_GCM_SHA384";
  617. break;
  618. case TLS_DH_DSS_WITH_AES_128_GCM_SHA256:
  619. return "TLS_DH_DSS_WITH_AES_128_GCM_SHA256";
  620. break;
  621. case TLS_DH_DSS_WITH_AES_256_GCM_SHA384:
  622. return "TLS_DH_DSS_WITH_AES_256_GCM_SHA384";
  623. break;
  624. case TLS_DH_anon_WITH_AES_128_GCM_SHA256:
  625. return "TLS_DH_anon_WITH_AES_128_GCM_SHA256";
  626. break;
  627. case TLS_DH_anon_WITH_AES_256_GCM_SHA384:
  628. return "TLS_DH_anon_WITH_AES_256_GCM_SHA384";
  629. break;
  630. /* TLS 1.2 with elliptic curve ciphers (RFC 5289) */
  631. case TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256:
  632. return "TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256";
  633. break;
  634. case TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA384:
  635. return "TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA384";
  636. break;
  637. case TLS_ECDH_ECDSA_WITH_AES_128_CBC_SHA256:
  638. return "TLS_ECDH_ECDSA_WITH_AES_128_CBC_SHA256";
  639. break;
  640. case TLS_ECDH_ECDSA_WITH_AES_256_CBC_SHA384:
  641. return "TLS_ECDH_ECDSA_WITH_AES_256_CBC_SHA384";
  642. break;
  643. case TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256:
  644. return "TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256";
  645. break;
  646. case TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384:
  647. return "TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384";
  648. break;
  649. case TLS_ECDH_RSA_WITH_AES_128_CBC_SHA256:
  650. return "TLS_ECDH_RSA_WITH_AES_128_CBC_SHA256";
  651. break;
  652. case TLS_ECDH_RSA_WITH_AES_256_CBC_SHA384:
  653. return "TLS_ECDH_RSA_WITH_AES_256_CBC_SHA384";
  654. break;
  655. case TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256:
  656. return "TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256";
  657. break;
  658. case TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384:
  659. return "TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384";
  660. break;
  661. case TLS_ECDH_ECDSA_WITH_AES_128_GCM_SHA256:
  662. return "TLS_ECDH_ECDSA_WITH_AES_128_GCM_SHA256";
  663. break;
  664. case TLS_ECDH_ECDSA_WITH_AES_256_GCM_SHA384:
  665. return "TLS_ECDH_ECDSA_WITH_AES_256_GCM_SHA384";
  666. break;
  667. case TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256:
  668. return "TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256";
  669. break;
  670. case TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384:
  671. return "TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384";
  672. break;
  673. case TLS_ECDH_RSA_WITH_AES_128_GCM_SHA256:
  674. return "TLS_ECDH_RSA_WITH_AES_128_GCM_SHA256";
  675. break;
  676. case TLS_ECDH_RSA_WITH_AES_256_GCM_SHA384:
  677. return "TLS_ECDH_RSA_WITH_AES_256_GCM_SHA384";
  678. break;
  679. case TLS_EMPTY_RENEGOTIATION_INFO_SCSV:
  680. return "TLS_EMPTY_RENEGOTIATION_INFO_SCSV";
  681. break;
  682. #else
  683. case SSL_RSA_WITH_NULL_MD5:
  684. return "TLS_RSA_WITH_NULL_MD5";
  685. break;
  686. case SSL_RSA_WITH_NULL_SHA:
  687. return "TLS_RSA_WITH_NULL_SHA";
  688. break;
  689. case SSL_RSA_WITH_RC4_128_MD5:
  690. return "TLS_RSA_WITH_RC4_128_MD5";
  691. break;
  692. case SSL_RSA_WITH_RC4_128_SHA:
  693. return "TLS_RSA_WITH_RC4_128_SHA";
  694. break;
  695. case SSL_RSA_WITH_3DES_EDE_CBC_SHA:
  696. return "TLS_RSA_WITH_3DES_EDE_CBC_SHA";
  697. break;
  698. case SSL_DH_anon_WITH_RC4_128_MD5:
  699. return "TLS_DH_anon_WITH_RC4_128_MD5";
  700. break;
  701. case SSL_DH_anon_WITH_3DES_EDE_CBC_SHA:
  702. return "TLS_DH_anon_WITH_3DES_EDE_CBC_SHA";
  703. break;
  704. #endif /* CURL_BUILD_MAC_10_8 || CURL_BUILD_IOS */
  705. #if CURL_BUILD_MAC_10_9 || CURL_BUILD_IOS_7
  706. /* TLS PSK (RFC 4279): */
  707. case TLS_PSK_WITH_RC4_128_SHA:
  708. return "TLS_PSK_WITH_RC4_128_SHA";
  709. break;
  710. case TLS_PSK_WITH_3DES_EDE_CBC_SHA:
  711. return "TLS_PSK_WITH_3DES_EDE_CBC_SHA";
  712. break;
  713. case TLS_PSK_WITH_AES_128_CBC_SHA:
  714. return "TLS_PSK_WITH_AES_128_CBC_SHA";
  715. break;
  716. case TLS_PSK_WITH_AES_256_CBC_SHA:
  717. return "TLS_PSK_WITH_AES_256_CBC_SHA";
  718. break;
  719. case TLS_DHE_PSK_WITH_RC4_128_SHA:
  720. return "TLS_DHE_PSK_WITH_RC4_128_SHA";
  721. break;
  722. case TLS_DHE_PSK_WITH_3DES_EDE_CBC_SHA:
  723. return "TLS_DHE_PSK_WITH_3DES_EDE_CBC_SHA";
  724. break;
  725. case TLS_DHE_PSK_WITH_AES_128_CBC_SHA:
  726. return "TLS_DHE_PSK_WITH_AES_128_CBC_SHA";
  727. break;
  728. case TLS_DHE_PSK_WITH_AES_256_CBC_SHA:
  729. return "TLS_DHE_PSK_WITH_AES_256_CBC_SHA";
  730. break;
  731. case TLS_RSA_PSK_WITH_RC4_128_SHA:
  732. return "TLS_RSA_PSK_WITH_RC4_128_SHA";
  733. break;
  734. case TLS_RSA_PSK_WITH_3DES_EDE_CBC_SHA:
  735. return "TLS_RSA_PSK_WITH_3DES_EDE_CBC_SHA";
  736. break;
  737. case TLS_RSA_PSK_WITH_AES_128_CBC_SHA:
  738. return "TLS_RSA_PSK_WITH_AES_128_CBC_SHA";
  739. break;
  740. case TLS_RSA_PSK_WITH_AES_256_CBC_SHA:
  741. return "TLS_RSA_PSK_WITH_AES_256_CBC_SHA";
  742. break;
  743. /* More TLS PSK (RFC 4785): */
  744. case TLS_PSK_WITH_NULL_SHA:
  745. return "TLS_PSK_WITH_NULL_SHA";
  746. break;
  747. case TLS_DHE_PSK_WITH_NULL_SHA:
  748. return "TLS_DHE_PSK_WITH_NULL_SHA";
  749. break;
  750. case TLS_RSA_PSK_WITH_NULL_SHA:
  751. return "TLS_RSA_PSK_WITH_NULL_SHA";
  752. break;
  753. /* Even more TLS PSK (RFC 5487): */
  754. case TLS_PSK_WITH_AES_128_GCM_SHA256:
  755. return "TLS_PSK_WITH_AES_128_GCM_SHA256";
  756. break;
  757. case TLS_PSK_WITH_AES_256_GCM_SHA384:
  758. return "TLS_PSK_WITH_AES_256_GCM_SHA384";
  759. break;
  760. case TLS_DHE_PSK_WITH_AES_128_GCM_SHA256:
  761. return "TLS_DHE_PSK_WITH_AES_128_GCM_SHA256";
  762. break;
  763. case TLS_DHE_PSK_WITH_AES_256_GCM_SHA384:
  764. return "TLS_DHE_PSK_WITH_AES_256_GCM_SHA384";
  765. break;
  766. case TLS_RSA_PSK_WITH_AES_128_GCM_SHA256:
  767. return "TLS_RSA_PSK_WITH_AES_128_GCM_SHA256";
  768. break;
  769. case TLS_RSA_PSK_WITH_AES_256_GCM_SHA384:
  770. return "TLS_PSK_WITH_AES_256_GCM_SHA384";
  771. break;
  772. case TLS_PSK_WITH_AES_128_CBC_SHA256:
  773. return "TLS_PSK_WITH_AES_128_CBC_SHA256";
  774. break;
  775. case TLS_PSK_WITH_AES_256_CBC_SHA384:
  776. return "TLS_PSK_WITH_AES_256_CBC_SHA384";
  777. break;
  778. case TLS_PSK_WITH_NULL_SHA256:
  779. return "TLS_PSK_WITH_NULL_SHA256";
  780. break;
  781. case TLS_PSK_WITH_NULL_SHA384:
  782. return "TLS_PSK_WITH_NULL_SHA384";
  783. break;
  784. case TLS_DHE_PSK_WITH_AES_128_CBC_SHA256:
  785. return "TLS_DHE_PSK_WITH_AES_128_CBC_SHA256";
  786. break;
  787. case TLS_DHE_PSK_WITH_AES_256_CBC_SHA384:
  788. return "TLS_DHE_PSK_WITH_AES_256_CBC_SHA384";
  789. break;
  790. case TLS_DHE_PSK_WITH_NULL_SHA256:
  791. return "TLS_DHE_PSK_WITH_NULL_SHA256";
  792. break;
  793. case TLS_DHE_PSK_WITH_NULL_SHA384:
  794. return "TLS_RSA_PSK_WITH_NULL_SHA384";
  795. break;
  796. case TLS_RSA_PSK_WITH_AES_128_CBC_SHA256:
  797. return "TLS_RSA_PSK_WITH_AES_128_CBC_SHA256";
  798. break;
  799. case TLS_RSA_PSK_WITH_AES_256_CBC_SHA384:
  800. return "TLS_RSA_PSK_WITH_AES_256_CBC_SHA384";
  801. break;
  802. case TLS_RSA_PSK_WITH_NULL_SHA256:
  803. return "TLS_RSA_PSK_WITH_NULL_SHA256";
  804. break;
  805. case TLS_RSA_PSK_WITH_NULL_SHA384:
  806. return "TLS_RSA_PSK_WITH_NULL_SHA384";
  807. break;
  808. #endif /* CURL_BUILD_MAC_10_9 || CURL_BUILD_IOS_7 */
  809. #if CURL_BUILD_MAC_10_13 || CURL_BUILD_IOS_11
  810. /* New ChaCha20+Poly1305 cipher-suites used by TLS 1.3: */
  811. case TLS_AES_128_GCM_SHA256:
  812. return "TLS_AES_128_GCM_SHA256";
  813. break;
  814. case TLS_AES_256_GCM_SHA384:
  815. return "TLS_AES_256_GCM_SHA384";
  816. break;
  817. case TLS_CHACHA20_POLY1305_SHA256:
  818. return "TLS_CHACHA20_POLY1305_SHA256";
  819. break;
  820. case TLS_AES_128_CCM_SHA256:
  821. return "TLS_AES_128_CCM_SHA256";
  822. break;
  823. case TLS_AES_128_CCM_8_SHA256:
  824. return "TLS_AES_128_CCM_8_SHA256";
  825. break;
  826. case TLS_ECDHE_RSA_WITH_CHACHA20_POLY1305_SHA256:
  827. return "TLS_ECDHE_RSA_WITH_CHACHA20_POLY1305_SHA256";
  828. break;
  829. case TLS_ECDHE_ECDSA_WITH_CHACHA20_POLY1305_SHA256:
  830. return "TLS_ECDHE_ECDSA_WITH_CHACHA20_POLY1305_SHA256";
  831. break;
  832. #endif /* CURL_BUILD_MAC_10_13 || CURL_BUILD_IOS_11 */
  833. }
  834. return "TLS_NULL_WITH_NULL_NULL";
  835. }
  836. #endif /* !CURL_DISABLE_VERBOSE_STRINGS */
  837. #if CURL_BUILD_MAC
  838. CF_INLINE void GetDarwinVersionNumber(int *major, int *minor)
  839. {
  840. int mib[2];
  841. char *os_version;
  842. size_t os_version_len;
  843. char *os_version_major, *os_version_minor;
  844. char *tok_buf;
  845. /* Get the Darwin kernel version from the kernel using sysctl(): */
  846. mib[0] = CTL_KERN;
  847. mib[1] = KERN_OSRELEASE;
  848. if(sysctl(mib, 2, NULL, &os_version_len, NULL, 0) == -1)
  849. return;
  850. os_version = malloc(os_version_len*sizeof(char));
  851. if(!os_version)
  852. return;
  853. if(sysctl(mib, 2, os_version, &os_version_len, NULL, 0) == -1) {
  854. free(os_version);
  855. return;
  856. }
  857. /* Parse the version: */
  858. os_version_major = strtok_r(os_version, ".", &tok_buf);
  859. os_version_minor = strtok_r(NULL, ".", &tok_buf);
  860. *major = atoi(os_version_major);
  861. *minor = atoi(os_version_minor);
  862. free(os_version);
  863. }
  864. #endif /* CURL_BUILD_MAC */
  865. /* Apple provides a myriad of ways of getting information about a certificate
  866. into a string. Some aren't available under iOS or newer cats. So here's
  867. a unified function for getting a string describing the certificate that
  868. ought to work in all cats starting with Leopard. */
  869. CF_INLINE CFStringRef getsubject(SecCertificateRef cert)
  870. {
  871. CFStringRef server_cert_summary = CFSTR("(null)");
  872. #if CURL_BUILD_IOS
  873. /* iOS: There's only one way to do this. */
  874. server_cert_summary = SecCertificateCopySubjectSummary(cert);
  875. #else
  876. #if CURL_BUILD_MAC_10_7
  877. /* Lion & later: Get the long description if we can. */
  878. if(SecCertificateCopyLongDescription != NULL)
  879. server_cert_summary =
  880. SecCertificateCopyLongDescription(NULL, cert, NULL);
  881. else
  882. #endif /* CURL_BUILD_MAC_10_7 */
  883. #if CURL_BUILD_MAC_10_6
  884. /* Snow Leopard: Get the certificate summary. */
  885. if(SecCertificateCopySubjectSummary != NULL)
  886. server_cert_summary = SecCertificateCopySubjectSummary(cert);
  887. else
  888. #endif /* CURL_BUILD_MAC_10_6 */
  889. /* Leopard is as far back as we go... */
  890. (void)SecCertificateCopyCommonName(cert, &server_cert_summary);
  891. #endif /* CURL_BUILD_IOS */
  892. return server_cert_summary;
  893. }
  894. static CURLcode CopyCertSubject(struct Curl_easy *data,
  895. SecCertificateRef cert, char **certp)
  896. {
  897. CFStringRef c = getsubject(cert);
  898. CURLcode result = CURLE_OK;
  899. const char *direct;
  900. char *cbuf = NULL;
  901. *certp = NULL;
  902. if(!c) {
  903. failf(data, "SSL: invalid CA certificate subject");
  904. return CURLE_OUT_OF_MEMORY;
  905. }
  906. /* If the subject is already available as UTF-8 encoded (ie 'direct') then
  907. use that, else convert it. */
  908. direct = CFStringGetCStringPtr(c, kCFStringEncodingUTF8);
  909. if(direct) {
  910. *certp = strdup(direct);
  911. if(!*certp) {
  912. failf(data, "SSL: out of memory");
  913. result = CURLE_OUT_OF_MEMORY;
  914. }
  915. }
  916. else {
  917. size_t cbuf_size = ((size_t)CFStringGetLength(c) * 4) + 1;
  918. cbuf = calloc(cbuf_size, 1);
  919. if(cbuf) {
  920. if(!CFStringGetCString(c, cbuf, cbuf_size,
  921. kCFStringEncodingUTF8)) {
  922. failf(data, "SSL: invalid CA certificate subject");
  923. result = CURLE_SSL_CACERT;
  924. }
  925. else
  926. /* pass back the buffer */
  927. *certp = cbuf;
  928. }
  929. else {
  930. failf(data, "SSL: couldn't allocate %zu bytes of memory", cbuf_size);
  931. result = CURLE_OUT_OF_MEMORY;
  932. }
  933. }
  934. if(result)
  935. free(cbuf);
  936. CFRelease(c);
  937. return result;
  938. }
  939. #if CURL_SUPPORT_MAC_10_6
  940. /* The SecKeychainSearch API was deprecated in Lion, and using it will raise
  941. deprecation warnings, so let's not compile this unless it's necessary: */
  942. static OSStatus CopyIdentityWithLabelOldSchool(char *label,
  943. SecIdentityRef *out_c_a_k)
  944. {
  945. OSStatus status = errSecItemNotFound;
  946. SecKeychainAttributeList attr_list;
  947. SecKeychainAttribute attr;
  948. SecKeychainSearchRef search = NULL;
  949. SecCertificateRef cert = NULL;
  950. /* Set up the attribute list: */
  951. attr_list.count = 1L;
  952. attr_list.attr = &attr;
  953. /* Set up our lone search criterion: */
  954. attr.tag = kSecLabelItemAttr;
  955. attr.data = label;
  956. attr.length = (UInt32)strlen(label);
  957. /* Start searching: */
  958. status = SecKeychainSearchCreateFromAttributes(NULL,
  959. kSecCertificateItemClass,
  960. &attr_list,
  961. &search);
  962. if(status == noErr) {
  963. status = SecKeychainSearchCopyNext(search,
  964. (SecKeychainItemRef *)&cert);
  965. if(status == noErr && cert) {
  966. /* If we found a certificate, does it have a private key? */
  967. status = SecIdentityCreateWithCertificate(NULL, cert, out_c_a_k);
  968. CFRelease(cert);
  969. }
  970. }
  971. if(search)
  972. CFRelease(search);
  973. return status;
  974. }
  975. #endif /* CURL_SUPPORT_MAC_10_6 */
  976. static OSStatus CopyIdentityWithLabel(char *label,
  977. SecIdentityRef *out_cert_and_key)
  978. {
  979. OSStatus status = errSecItemNotFound;
  980. #if CURL_BUILD_MAC_10_7 || CURL_BUILD_IOS
  981. CFArrayRef keys_list;
  982. CFIndex keys_list_count;
  983. CFIndex i;
  984. CFStringRef common_name;
  985. /* SecItemCopyMatching() was introduced in iOS and Snow Leopard.
  986. kSecClassIdentity was introduced in Lion. If both exist, let's use them
  987. to find the certificate. */
  988. if(SecItemCopyMatching != NULL && kSecClassIdentity != NULL) {
  989. CFTypeRef keys[5];
  990. CFTypeRef values[5];
  991. CFDictionaryRef query_dict;
  992. CFStringRef label_cf = CFStringCreateWithCString(NULL, label,
  993. kCFStringEncodingUTF8);
  994. /* Set up our search criteria and expected results: */
  995. values[0] = kSecClassIdentity; /* we want a certificate and a key */
  996. keys[0] = kSecClass;
  997. values[1] = kCFBooleanTrue; /* we want a reference */
  998. keys[1] = kSecReturnRef;
  999. values[2] = kSecMatchLimitAll; /* kSecMatchLimitOne would be better if the
  1000. * label matching below worked correctly */
  1001. keys[2] = kSecMatchLimit;
  1002. /* identity searches need a SecPolicyRef in order to work */
  1003. values[3] = SecPolicyCreateSSL(false, NULL);
  1004. keys[3] = kSecMatchPolicy;
  1005. /* match the name of the certificate (doesn't work in macOS 10.12.1) */
  1006. values[4] = label_cf;
  1007. keys[4] = kSecAttrLabel;
  1008. query_dict = CFDictionaryCreate(NULL, (const void **)keys,
  1009. (const void **)values, 5L,
  1010. &kCFCopyStringDictionaryKeyCallBacks,
  1011. &kCFTypeDictionaryValueCallBacks);
  1012. CFRelease(values[3]);
  1013. /* Do we have a match? */
  1014. status = SecItemCopyMatching(query_dict, (CFTypeRef *) &keys_list);
  1015. /* Because kSecAttrLabel matching doesn't work with kSecClassIdentity,
  1016. * we need to find the correct identity ourselves */
  1017. if(status == noErr) {
  1018. keys_list_count = CFArrayGetCount(keys_list);
  1019. *out_cert_and_key = NULL;
  1020. status = 1;
  1021. for(i = 0; i<keys_list_count; i++) {
  1022. OSStatus err = noErr;
  1023. SecCertificateRef cert = NULL;
  1024. SecIdentityRef identity =
  1025. (SecIdentityRef) CFArrayGetValueAtIndex(keys_list, i);
  1026. err = SecIdentityCopyCertificate(identity, &cert);
  1027. if(err == noErr) {
  1028. #if CURL_BUILD_IOS
  1029. common_name = SecCertificateCopySubjectSummary(cert);
  1030. #elif CURL_BUILD_MAC_10_7
  1031. SecCertificateCopyCommonName(cert, &common_name);
  1032. #endif
  1033. if(CFStringCompare(common_name, label_cf, 0) == kCFCompareEqualTo) {
  1034. CFRelease(cert);
  1035. CFRelease(common_name);
  1036. CFRetain(identity);
  1037. *out_cert_and_key = identity;
  1038. status = noErr;
  1039. break;
  1040. }
  1041. CFRelease(common_name);
  1042. }
  1043. CFRelease(cert);
  1044. }
  1045. }
  1046. if(keys_list)
  1047. CFRelease(keys_list);
  1048. CFRelease(query_dict);
  1049. CFRelease(label_cf);
  1050. }
  1051. else {
  1052. #if CURL_SUPPORT_MAC_10_6
  1053. /* On Leopard and Snow Leopard, fall back to SecKeychainSearch. */
  1054. status = CopyIdentityWithLabelOldSchool(label, out_cert_and_key);
  1055. #endif /* CURL_SUPPORT_MAC_10_6 */
  1056. }
  1057. #elif CURL_SUPPORT_MAC_10_6
  1058. /* For developers building on older cats, we have no choice but to fall back
  1059. to SecKeychainSearch. */
  1060. status = CopyIdentityWithLabelOldSchool(label, out_cert_and_key);
  1061. #endif /* CURL_BUILD_MAC_10_7 || CURL_BUILD_IOS */
  1062. return status;
  1063. }
  1064. static OSStatus CopyIdentityFromPKCS12File(const char *cPath,
  1065. const char *cPassword,
  1066. SecIdentityRef *out_cert_and_key)
  1067. {
  1068. OSStatus status = errSecItemNotFound;
  1069. CFURLRef pkcs_url = CFURLCreateFromFileSystemRepresentation(NULL,
  1070. (const UInt8 *)cPath, strlen(cPath), false);
  1071. CFStringRef password = cPassword ? CFStringCreateWithCString(NULL,
  1072. cPassword, kCFStringEncodingUTF8) : NULL;
  1073. CFDataRef pkcs_data = NULL;
  1074. /* We can import P12 files on iOS or OS X 10.7 or later: */
  1075. /* These constants are documented as having first appeared in 10.6 but they
  1076. raise linker errors when used on that cat for some reason. */
  1077. #if CURL_BUILD_MAC_10_7 || CURL_BUILD_IOS
  1078. if(CFURLCreateDataAndPropertiesFromResource(NULL, pkcs_url, &pkcs_data,
  1079. NULL, NULL, &status)) {
  1080. CFArrayRef items = NULL;
  1081. /* On iOS SecPKCS12Import will never add the client certificate to the
  1082. * Keychain.
  1083. *
  1084. * It gives us back a SecIdentityRef that we can use directly. */
  1085. #if CURL_BUILD_IOS
  1086. const void *cKeys[] = {kSecImportExportPassphrase};
  1087. const void *cValues[] = {password};
  1088. CFDictionaryRef options = CFDictionaryCreate(NULL, cKeys, cValues,
  1089. password ? 1L : 0L, NULL, NULL);
  1090. if(options != NULL) {
  1091. status = SecPKCS12Import(pkcs_data, options, &items);
  1092. CFRelease(options);
  1093. }
  1094. /* On macOS SecPKCS12Import will always add the client certificate to
  1095. * the Keychain.
  1096. *
  1097. * As this doesn't match iOS, and apps may not want to see their client
  1098. * certificate saved in the the user's keychain, we use SecItemImport
  1099. * with a NULL keychain to avoid importing it.
  1100. *
  1101. * This returns a SecCertificateRef from which we can construct a
  1102. * SecIdentityRef.
  1103. */
  1104. #elif CURL_BUILD_MAC_10_7
  1105. SecItemImportExportKeyParameters keyParams;
  1106. SecExternalFormat inputFormat = kSecFormatPKCS12;
  1107. SecExternalItemType inputType = kSecItemTypeCertificate;
  1108. memset(&keyParams, 0x00, sizeof(keyParams));
  1109. keyParams.version = SEC_KEY_IMPORT_EXPORT_PARAMS_VERSION;
  1110. keyParams.passphrase = password;
  1111. status = SecItemImport(pkcs_data, NULL, &inputFormat, &inputType,
  1112. 0, &keyParams, NULL, &items);
  1113. #endif
  1114. /* Extract the SecIdentityRef */
  1115. if(status == errSecSuccess && items && CFArrayGetCount(items)) {
  1116. CFIndex i, count;
  1117. count = CFArrayGetCount(items);
  1118. for(i = 0; i < count; i++) {
  1119. CFTypeRef item = (CFTypeRef) CFArrayGetValueAtIndex(items, i);
  1120. CFTypeID itemID = CFGetTypeID(item);
  1121. if(itemID == CFDictionaryGetTypeID()) {
  1122. CFTypeRef identity = (CFTypeRef) CFDictionaryGetValue(
  1123. (CFDictionaryRef) item,
  1124. kSecImportItemIdentity);
  1125. CFRetain(identity);
  1126. *out_cert_and_key = (SecIdentityRef) identity;
  1127. break;
  1128. }
  1129. #if CURL_BUILD_MAC_10_7
  1130. else if(itemID == SecCertificateGetTypeID()) {
  1131. status = SecIdentityCreateWithCertificate(NULL,
  1132. (SecCertificateRef) item,
  1133. out_cert_and_key);
  1134. break;
  1135. }
  1136. #endif
  1137. }
  1138. }
  1139. if(items)
  1140. CFRelease(items);
  1141. CFRelease(pkcs_data);
  1142. }
  1143. #endif /* CURL_BUILD_MAC_10_7 || CURL_BUILD_IOS */
  1144. if(password)
  1145. CFRelease(password);
  1146. CFRelease(pkcs_url);
  1147. return status;
  1148. }
  1149. /* This code was borrowed from nss.c, with some modifications:
  1150. * Determine whether the nickname passed in is a filename that needs to
  1151. * be loaded as a PEM or a regular NSS nickname.
  1152. *
  1153. * returns 1 for a file
  1154. * returns 0 for not a file
  1155. */
  1156. CF_INLINE bool is_file(const char *filename)
  1157. {
  1158. struct_stat st;
  1159. if(filename == NULL)
  1160. return false;
  1161. if(stat(filename, &st) == 0)
  1162. return S_ISREG(st.st_mode);
  1163. return false;
  1164. }
  1165. #if CURL_BUILD_MAC_10_8 || CURL_BUILD_IOS
  1166. static CURLcode darwinssl_version_from_curl(SSLProtocol *darwinver,
  1167. long ssl_version)
  1168. {
  1169. switch(ssl_version) {
  1170. case CURL_SSLVERSION_TLSv1_0:
  1171. *darwinver = kTLSProtocol1;
  1172. return CURLE_OK;
  1173. case CURL_SSLVERSION_TLSv1_1:
  1174. *darwinver = kTLSProtocol11;
  1175. return CURLE_OK;
  1176. case CURL_SSLVERSION_TLSv1_2:
  1177. *darwinver = kTLSProtocol12;
  1178. return CURLE_OK;
  1179. case CURL_SSLVERSION_TLSv1_3:
  1180. /* TLS 1.3 support first appeared in iOS 11 and macOS 10.13 */
  1181. #if (CURL_BUILD_MAC_10_13 || CURL_BUILD_IOS_11) && HAVE_BUILTIN_AVAILABLE == 1
  1182. if(__builtin_available(macOS 10.13, iOS 11.0, *)) {
  1183. *darwinver = kTLSProtocol13;
  1184. return CURLE_OK;
  1185. }
  1186. #endif /* (CURL_BUILD_MAC_10_13 || CURL_BUILD_IOS_11) &&
  1187. HAVE_BUILTIN_AVAILABLE == 1 */
  1188. break;
  1189. }
  1190. return CURLE_SSL_CONNECT_ERROR;
  1191. }
  1192. #endif
  1193. static CURLcode
  1194. set_ssl_version_min_max(struct connectdata *conn, int sockindex)
  1195. {
  1196. struct Curl_easy *data = conn->data;
  1197. struct ssl_connect_data *connssl = &conn->ssl[sockindex];
  1198. long ssl_version = SSL_CONN_CONFIG(version);
  1199. long ssl_version_max = SSL_CONN_CONFIG(version_max);
  1200. long max_supported_version_by_os;
  1201. /* macOS 10.5-10.7 supported TLS 1.0 only.
  1202. macOS 10.8 and later, and iOS 5 and later, added TLS 1.1 and 1.2.
  1203. macOS 10.13 and later, and iOS 11 and later, added TLS 1.3. */
  1204. #if (CURL_BUILD_MAC_10_13 || CURL_BUILD_IOS_11) && HAVE_BUILTIN_AVAILABLE == 1
  1205. if(__builtin_available(macOS 10.13, iOS 11.0, *)) {
  1206. max_supported_version_by_os = CURL_SSLVERSION_MAX_TLSv1_3;
  1207. }
  1208. else {
  1209. max_supported_version_by_os = CURL_SSLVERSION_MAX_TLSv1_2;
  1210. }
  1211. #else
  1212. max_supported_version_by_os = CURL_SSLVERSION_MAX_TLSv1_2;
  1213. #endif /* (CURL_BUILD_MAC_10_13 || CURL_BUILD_IOS_11) &&
  1214. HAVE_BUILTIN_AVAILABLE == 1 */
  1215. switch(ssl_version) {
  1216. case CURL_SSLVERSION_DEFAULT:
  1217. case CURL_SSLVERSION_TLSv1:
  1218. ssl_version = CURL_SSLVERSION_TLSv1_0;
  1219. ssl_version_max = max_supported_version_by_os;
  1220. break;
  1221. }
  1222. switch(ssl_version_max) {
  1223. case CURL_SSLVERSION_MAX_NONE:
  1224. ssl_version_max = ssl_version << 16;
  1225. break;
  1226. case CURL_SSLVERSION_MAX_DEFAULT:
  1227. ssl_version_max = max_supported_version_by_os;
  1228. break;
  1229. }
  1230. #if CURL_BUILD_MAC_10_8 || CURL_BUILD_IOS
  1231. if(SSLSetProtocolVersionMax != NULL) {
  1232. SSLProtocol darwin_ver_min = kTLSProtocol1;
  1233. SSLProtocol darwin_ver_max = kTLSProtocol1;
  1234. CURLcode result = darwinssl_version_from_curl(&darwin_ver_min,
  1235. ssl_version);
  1236. if(result) {
  1237. failf(data, "unsupported min version passed via CURLOPT_SSLVERSION");
  1238. return result;
  1239. }
  1240. result = darwinssl_version_from_curl(&darwin_ver_max,
  1241. ssl_version_max >> 16);
  1242. if(result) {
  1243. failf(data, "unsupported max version passed via CURLOPT_SSLVERSION");
  1244. return result;
  1245. }
  1246. (void)SSLSetProtocolVersionMin(BACKEND->ssl_ctx, darwin_ver_min);
  1247. (void)SSLSetProtocolVersionMax(BACKEND->ssl_ctx, darwin_ver_max);
  1248. return result;
  1249. }
  1250. else {
  1251. #if CURL_SUPPORT_MAC_10_8
  1252. long i = ssl_version;
  1253. (void)SSLSetProtocolVersionEnabled(BACKEND->ssl_ctx,
  1254. kSSLProtocolAll,
  1255. false);
  1256. for(; i <= (ssl_version_max >> 16); i++) {
  1257. switch(i) {
  1258. case CURL_SSLVERSION_TLSv1_0:
  1259. (void)SSLSetProtocolVersionEnabled(BACKEND->ssl_ctx,
  1260. kTLSProtocol1,
  1261. true);
  1262. break;
  1263. case CURL_SSLVERSION_TLSv1_1:
  1264. (void)SSLSetProtocolVersionEnabled(BACKEND->ssl_ctx,
  1265. kTLSProtocol11,
  1266. true);
  1267. break;
  1268. case CURL_SSLVERSION_TLSv1_2:
  1269. (void)SSLSetProtocolVersionEnabled(BACKEND->ssl_ctx,
  1270. kTLSProtocol12,
  1271. true);
  1272. break;
  1273. case CURL_SSLVERSION_TLSv1_3:
  1274. failf(data, "Your version of the OS does not support TLSv1.3");
  1275. return CURLE_SSL_CONNECT_ERROR;
  1276. }
  1277. }
  1278. return CURLE_OK;
  1279. #endif /* CURL_SUPPORT_MAC_10_8 */
  1280. }
  1281. #endif /* CURL_BUILD_MAC_10_8 || CURL_BUILD_IOS */
  1282. failf(data, "DarwinSSL: cannot set SSL protocol");
  1283. return CURLE_SSL_CONNECT_ERROR;
  1284. }
  1285. static CURLcode darwinssl_connect_step1(struct connectdata *conn,
  1286. int sockindex)
  1287. {
  1288. struct Curl_easy *data = conn->data;
  1289. curl_socket_t sockfd = conn->sock[sockindex];
  1290. struct ssl_connect_data *connssl = &conn->ssl[sockindex];
  1291. const char * const ssl_cafile = SSL_CONN_CONFIG(CAfile);
  1292. const bool verifypeer = SSL_CONN_CONFIG(verifypeer);
  1293. char * const ssl_cert = SSL_SET_OPTION(cert);
  1294. const char * const hostname = SSL_IS_PROXY() ? conn->http_proxy.host.name :
  1295. conn->host.name;
  1296. const long int port = SSL_IS_PROXY() ? conn->port : conn->remote_port;
  1297. #ifdef ENABLE_IPV6
  1298. struct in6_addr addr;
  1299. #else
  1300. struct in_addr addr;
  1301. #endif /* ENABLE_IPV6 */
  1302. size_t all_ciphers_count = 0UL, allowed_ciphers_count = 0UL, i;
  1303. SSLCipherSuite *all_ciphers = NULL, *allowed_ciphers = NULL;
  1304. OSStatus err = noErr;
  1305. #if CURL_BUILD_MAC
  1306. int darwinver_maj = 0, darwinver_min = 0;
  1307. GetDarwinVersionNumber(&darwinver_maj, &darwinver_min);
  1308. #endif /* CURL_BUILD_MAC */
  1309. #if CURL_BUILD_MAC_10_8 || CURL_BUILD_IOS
  1310. if(SSLCreateContext != NULL) { /* use the newer API if available */
  1311. if(BACKEND->ssl_ctx)
  1312. CFRelease(BACKEND->ssl_ctx);
  1313. BACKEND->ssl_ctx = SSLCreateContext(NULL, kSSLClientSide, kSSLStreamType);
  1314. if(!BACKEND->ssl_ctx) {
  1315. failf(data, "SSL: couldn't create a context!");
  1316. return CURLE_OUT_OF_MEMORY;
  1317. }
  1318. }
  1319. else {
  1320. /* The old ST API does not exist under iOS, so don't compile it: */
  1321. #if CURL_SUPPORT_MAC_10_8
  1322. if(BACKEND->ssl_ctx)
  1323. (void)SSLDisposeContext(BACKEND->ssl_ctx);
  1324. err = SSLNewContext(false, &(BACKEND->ssl_ctx));
  1325. if(err != noErr) {
  1326. failf(data, "SSL: couldn't create a context: OSStatus %d", err);
  1327. return CURLE_OUT_OF_MEMORY;
  1328. }
  1329. #endif /* CURL_SUPPORT_MAC_10_8 */
  1330. }
  1331. #else
  1332. if(BACKEND->ssl_ctx)
  1333. (void)SSLDisposeContext(BACKEND->ssl_ctx);
  1334. err = SSLNewContext(false, &(BACKEND->ssl_ctx));
  1335. if(err != noErr) {
  1336. failf(data, "SSL: couldn't create a context: OSStatus %d", err);
  1337. return CURLE_OUT_OF_MEMORY;
  1338. }
  1339. #endif /* CURL_BUILD_MAC_10_8 || CURL_BUILD_IOS */
  1340. BACKEND->ssl_write_buffered_length = 0UL; /* reset buffered write length */
  1341. /* check to see if we've been told to use an explicit SSL/TLS version */
  1342. #if CURL_BUILD_MAC_10_8 || CURL_BUILD_IOS
  1343. if(SSLSetProtocolVersionMax != NULL) {
  1344. switch(conn->ssl_config.version) {
  1345. case CURL_SSLVERSION_DEFAULT:
  1346. case CURL_SSLVERSION_TLSv1:
  1347. (void)SSLSetProtocolVersionMin(BACKEND->ssl_ctx, kTLSProtocol1);
  1348. #if (CURL_BUILD_MAC_10_13 || CURL_BUILD_IOS_11) && HAVE_BUILTIN_AVAILABLE == 1
  1349. if(__builtin_available(macOS 10.13, iOS 11.0, *)) {
  1350. (void)SSLSetProtocolVersionMax(BACKEND->ssl_ctx, kTLSProtocol13);
  1351. }
  1352. else {
  1353. (void)SSLSetProtocolVersionMax(BACKEND->ssl_ctx, kTLSProtocol12);
  1354. }
  1355. #else
  1356. (void)SSLSetProtocolVersionMax(BACKEND->ssl_ctx, kTLSProtocol12);
  1357. #endif /* (CURL_BUILD_MAC_10_13 || CURL_BUILD_IOS_11) &&
  1358. HAVE_BUILTIN_AVAILABLE == 1 */
  1359. break;
  1360. case CURL_SSLVERSION_TLSv1_0:
  1361. case CURL_SSLVERSION_TLSv1_1:
  1362. case CURL_SSLVERSION_TLSv1_2:
  1363. case CURL_SSLVERSION_TLSv1_3:
  1364. {
  1365. CURLcode result = set_ssl_version_min_max(conn, sockindex);
  1366. if(result != CURLE_OK)
  1367. return result;
  1368. break;
  1369. }
  1370. case CURL_SSLVERSION_SSLv3:
  1371. err = SSLSetProtocolVersionMin(BACKEND->ssl_ctx, kSSLProtocol3);
  1372. if(err != noErr) {
  1373. failf(data, "Your version of the OS does not support SSLv3");
  1374. return CURLE_SSL_CONNECT_ERROR;
  1375. }
  1376. (void)SSLSetProtocolVersionMax(BACKEND->ssl_ctx, kSSLProtocol3);
  1377. break;
  1378. case CURL_SSLVERSION_SSLv2:
  1379. err = SSLSetProtocolVersionMin(BACKEND->ssl_ctx, kSSLProtocol2);
  1380. if(err != noErr) {
  1381. failf(data, "Your version of the OS does not support SSLv2");
  1382. return CURLE_SSL_CONNECT_ERROR;
  1383. }
  1384. (void)SSLSetProtocolVersionMax(BACKEND->ssl_ctx, kSSLProtocol2);
  1385. break;
  1386. default:
  1387. failf(data, "Unrecognized parameter passed via CURLOPT_SSLVERSION");
  1388. return CURLE_SSL_CONNECT_ERROR;
  1389. }
  1390. }
  1391. else {
  1392. #if CURL_SUPPORT_MAC_10_8
  1393. (void)SSLSetProtocolVersionEnabled(BACKEND->ssl_ctx,
  1394. kSSLProtocolAll,
  1395. false);
  1396. switch(conn->ssl_config.version) {
  1397. case CURL_SSLVERSION_DEFAULT:
  1398. case CURL_SSLVERSION_TLSv1:
  1399. (void)SSLSetProtocolVersionEnabled(BACKEND->ssl_ctx,
  1400. kTLSProtocol1,
  1401. true);
  1402. (void)SSLSetProtocolVersionEnabled(BACKEND->ssl_ctx,
  1403. kTLSProtocol11,
  1404. true);
  1405. (void)SSLSetProtocolVersionEnabled(BACKEND->ssl_ctx,
  1406. kTLSProtocol12,
  1407. true);
  1408. break;
  1409. case CURL_SSLVERSION_TLSv1_0:
  1410. case CURL_SSLVERSION_TLSv1_1:
  1411. case CURL_SSLVERSION_TLSv1_2:
  1412. case CURL_SSLVERSION_TLSv1_3:
  1413. {
  1414. CURLcode result = set_ssl_version_min_max(conn, sockindex);
  1415. if(result != CURLE_OK)
  1416. return result;
  1417. break;
  1418. }
  1419. case CURL_SSLVERSION_SSLv3:
  1420. err = SSLSetProtocolVersionEnabled(BACKEND->ssl_ctx,
  1421. kSSLProtocol3,
  1422. true);
  1423. if(err != noErr) {
  1424. failf(data, "Your version of the OS does not support SSLv3");
  1425. return CURLE_SSL_CONNECT_ERROR;
  1426. }
  1427. break;
  1428. case CURL_SSLVERSION_SSLv2:
  1429. err = SSLSetProtocolVersionEnabled(BACKEND->ssl_ctx,
  1430. kSSLProtocol2,
  1431. true);
  1432. if(err != noErr) {
  1433. failf(data, "Your version of the OS does not support SSLv2");
  1434. return CURLE_SSL_CONNECT_ERROR;
  1435. }
  1436. break;
  1437. default:
  1438. failf(data, "Unrecognized parameter passed via CURLOPT_SSLVERSION");
  1439. return CURLE_SSL_CONNECT_ERROR;
  1440. }
  1441. #endif /* CURL_SUPPORT_MAC_10_8 */
  1442. }
  1443. #else
  1444. if(conn->ssl_config.version_max != CURL_SSLVERSION_MAX_NONE) {
  1445. failf(data, "Your version of the OS does not support to set maximum"
  1446. " SSL/TLS version");
  1447. return CURLE_SSL_CONNECT_ERROR;
  1448. }
  1449. (void)SSLSetProtocolVersionEnabled(BACKEND->ssl_ctx, kSSLProtocolAll, false);
  1450. switch(conn->ssl_config.version) {
  1451. case CURL_SSLVERSION_DEFAULT:
  1452. case CURL_SSLVERSION_TLSv1:
  1453. case CURL_SSLVERSION_TLSv1_0:
  1454. (void)SSLSetProtocolVersionEnabled(BACKEND->ssl_ctx,
  1455. kTLSProtocol1,
  1456. true);
  1457. break;
  1458. case CURL_SSLVERSION_TLSv1_1:
  1459. failf(data, "Your version of the OS does not support TLSv1.1");
  1460. return CURLE_SSL_CONNECT_ERROR;
  1461. case CURL_SSLVERSION_TLSv1_2:
  1462. failf(data, "Your version of the OS does not support TLSv1.2");
  1463. return CURLE_SSL_CONNECT_ERROR;
  1464. case CURL_SSLVERSION_TLSv1_3:
  1465. failf(data, "Your version of the OS does not support TLSv1.3");
  1466. return CURLE_SSL_CONNECT_ERROR;
  1467. case CURL_SSLVERSION_SSLv2:
  1468. err = SSLSetProtocolVersionEnabled(BACKEND->ssl_ctx,
  1469. kSSLProtocol2,
  1470. true);
  1471. if(err != noErr) {
  1472. failf(data, "Your version of the OS does not support SSLv2");
  1473. return CURLE_SSL_CONNECT_ERROR;
  1474. }
  1475. break;
  1476. case CURL_SSLVERSION_SSLv3:
  1477. err = SSLSetProtocolVersionEnabled(BACKEND->ssl_ctx,
  1478. kSSLProtocol3,
  1479. true);
  1480. if(err != noErr) {
  1481. failf(data, "Your version of the OS does not support SSLv3");
  1482. return CURLE_SSL_CONNECT_ERROR;
  1483. }
  1484. break;
  1485. default:
  1486. failf(data, "Unrecognized parameter passed via CURLOPT_SSLVERSION");
  1487. return CURLE_SSL_CONNECT_ERROR;
  1488. }
  1489. #endif /* CURL_BUILD_MAC_10_8 || CURL_BUILD_IOS */
  1490. #if (CURL_BUILD_MAC_10_13 || CURL_BUILD_IOS_11) && HAVE_BUILTIN_AVAILABLE == 1
  1491. if(conn->bits.tls_enable_alpn) {
  1492. if(__builtin_available(macOS 10.13.4, iOS 11, *)) {
  1493. CFMutableArrayRef alpnArr = CFArrayCreateMutable(NULL, 0,
  1494. &kCFTypeArrayCallBacks);
  1495. #ifdef USE_NGHTTP2
  1496. if(data->set.httpversion >= CURL_HTTP_VERSION_2 &&
  1497. (!SSL_IS_PROXY() || !conn->bits.tunnel_proxy)) {
  1498. CFArrayAppendValue(alpnArr, CFSTR(NGHTTP2_PROTO_VERSION_ID));
  1499. infof(data, "ALPN, offering %s\n", NGHTTP2_PROTO_VERSION_ID);
  1500. }
  1501. #endif
  1502. CFArrayAppendValue(alpnArr, CFSTR(ALPN_HTTP_1_1));
  1503. infof(data, "ALPN, offering %s\n", ALPN_HTTP_1_1);
  1504. /* expects length prefixed preference ordered list of protocols in wire
  1505. * format
  1506. */
  1507. err = SSLSetALPNProtocols(BACKEND->ssl_ctx, alpnArr);
  1508. if(err != noErr)
  1509. infof(data, "WARNING: failed to set ALPN protocols; OSStatus %d\n",
  1510. err);
  1511. CFRelease(alpnArr);
  1512. }
  1513. }
  1514. #endif
  1515. if(SSL_SET_OPTION(key)) {
  1516. infof(data, "WARNING: SSL: CURLOPT_SSLKEY is ignored by Secure "
  1517. "Transport. The private key must be in the Keychain.\n");
  1518. }
  1519. if(ssl_cert) {
  1520. SecIdentityRef cert_and_key = NULL;
  1521. bool is_cert_file = is_file(ssl_cert);
  1522. /* User wants to authenticate with a client cert. Look for it:
  1523. If we detect that this is a file on disk, then let's load it.
  1524. Otherwise, assume that the user wants to use an identity loaded
  1525. from the Keychain. */
  1526. if(is_cert_file) {
  1527. if(!SSL_SET_OPTION(cert_type))
  1528. infof(data, "WARNING: SSL: Certificate type not set, assuming "
  1529. "PKCS#12 format.\n");
  1530. else if(strncmp(SSL_SET_OPTION(cert_type), "P12",
  1531. strlen(SSL_SET_OPTION(cert_type))) != 0)
  1532. infof(data, "WARNING: SSL: The Security framework only supports "
  1533. "loading identities that are in PKCS#12 format.\n");
  1534. err = CopyIdentityFromPKCS12File(ssl_cert,
  1535. SSL_SET_OPTION(key_passwd), &cert_and_key);
  1536. }
  1537. else
  1538. err = CopyIdentityWithLabel(ssl_cert, &cert_and_key);
  1539. if(err == noErr && cert_and_key) {
  1540. SecCertificateRef cert = NULL;
  1541. CFTypeRef certs_c[1];
  1542. CFArrayRef certs;
  1543. /* If we found one, print it out: */
  1544. err = SecIdentityCopyCertificate(cert_and_key, &cert);
  1545. if(err == noErr) {
  1546. char *certp;
  1547. CURLcode result = CopyCertSubject(data, cert, &certp);
  1548. if(!result) {
  1549. infof(data, "Client certificate: %s\n", certp);
  1550. free(certp);
  1551. }
  1552. CFRelease(cert);
  1553. if(result)
  1554. return result;
  1555. }
  1556. certs_c[0] = cert_and_key;
  1557. certs = CFArrayCreate(NULL, (const void **)certs_c, 1L,
  1558. &kCFTypeArrayCallBacks);
  1559. err = SSLSetCertificate(BACKEND->ssl_ctx, certs);
  1560. if(certs)
  1561. CFRelease(certs);
  1562. if(err != noErr) {
  1563. failf(data, "SSL: SSLSetCertificate() failed: OSStatus %d", err);
  1564. return CURLE_SSL_CERTPROBLEM;
  1565. }
  1566. CFRelease(cert_and_key);
  1567. }
  1568. else {
  1569. switch(err) {
  1570. case errSecAuthFailed: case -25264: /* errSecPkcs12VerifyFailure */
  1571. failf(data, "SSL: Incorrect password for the certificate \"%s\" "
  1572. "and its private key.", ssl_cert);
  1573. break;
  1574. case -26275: /* errSecDecode */ case -25257: /* errSecUnknownFormat */
  1575. failf(data, "SSL: Couldn't make sense of the data in the "
  1576. "certificate \"%s\" and its private key.",
  1577. ssl_cert);
  1578. break;
  1579. case -25260: /* errSecPassphraseRequired */
  1580. failf(data, "SSL The certificate \"%s\" requires a password.",
  1581. ssl_cert);
  1582. break;
  1583. case errSecItemNotFound:
  1584. failf(data, "SSL: Can't find the certificate \"%s\" and its private "
  1585. "key in the Keychain.", ssl_cert);
  1586. break;
  1587. default:
  1588. failf(data, "SSL: Can't load the certificate \"%s\" and its private "
  1589. "key: OSStatus %d", ssl_cert, err);
  1590. break;
  1591. }
  1592. return CURLE_SSL_CERTPROBLEM;
  1593. }
  1594. }
  1595. /* SSL always tries to verify the peer, this only says whether it should
  1596. * fail to connect if the verification fails, or if it should continue
  1597. * anyway. In the latter case the result of the verification is checked with
  1598. * SSL_get_verify_result() below. */
  1599. #if CURL_BUILD_MAC_10_6 || CURL_BUILD_IOS
  1600. /* Snow Leopard introduced the SSLSetSessionOption() function, but due to
  1601. a library bug with the way the kSSLSessionOptionBreakOnServerAuth flag
  1602. works, it doesn't work as expected under Snow Leopard, Lion or
  1603. Mountain Lion.
  1604. So we need to call SSLSetEnableCertVerify() on those older cats in order
  1605. to disable certificate validation if the user turned that off.
  1606. (SecureTransport will always validate the certificate chain by
  1607. default.)
  1608. Note:
  1609. Darwin 11.x.x is Lion (10.7)
  1610. Darwin 12.x.x is Mountain Lion (10.8)
  1611. Darwin 13.x.x is Mavericks (10.9)
  1612. Darwin 14.x.x is Yosemite (10.10)
  1613. Darwin 15.x.x is El Capitan (10.11)
  1614. */
  1615. #if CURL_BUILD_MAC
  1616. if(SSLSetSessionOption != NULL && darwinver_maj >= 13) {
  1617. #else
  1618. if(SSLSetSessionOption != NULL) {
  1619. #endif /* CURL_BUILD_MAC */
  1620. bool break_on_auth = !conn->ssl_config.verifypeer || ssl_cafile;
  1621. err = SSLSetSessionOption(BACKEND->ssl_ctx,
  1622. kSSLSessionOptionBreakOnServerAuth,
  1623. break_on_auth);
  1624. if(err != noErr) {
  1625. failf(data, "SSL: SSLSetSessionOption() failed: OSStatus %d", err);
  1626. return CURLE_SSL_CONNECT_ERROR;
  1627. }
  1628. }
  1629. else {
  1630. #if CURL_SUPPORT_MAC_10_8
  1631. err = SSLSetEnableCertVerify(BACKEND->ssl_ctx,
  1632. conn->ssl_config.verifypeer?true:false);
  1633. if(err != noErr) {
  1634. failf(data, "SSL: SSLSetEnableCertVerify() failed: OSStatus %d", err);
  1635. return CURLE_SSL_CONNECT_ERROR;
  1636. }
  1637. #endif /* CURL_SUPPORT_MAC_10_8 */
  1638. }
  1639. #else
  1640. err = SSLSetEnableCertVerify(BACKEND->ssl_ctx,
  1641. conn->ssl_config.verifypeer?true:false);
  1642. if(err != noErr) {
  1643. failf(data, "SSL: SSLSetEnableCertVerify() failed: OSStatus %d", err);
  1644. return CURLE_SSL_CONNECT_ERROR;
  1645. }
  1646. #endif /* CURL_BUILD_MAC_10_6 || CURL_BUILD_IOS */
  1647. if(ssl_cafile && verifypeer) {
  1648. bool is_cert_file = is_file(ssl_cafile);
  1649. if(!is_cert_file) {
  1650. failf(data, "SSL: can't load CA certificate file %s", ssl_cafile);
  1651. return CURLE_SSL_CACERT_BADFILE;
  1652. }
  1653. }
  1654. /* Configure hostname check. SNI is used if available.
  1655. * Both hostname check and SNI require SSLSetPeerDomainName().
  1656. * Also: the verifyhost setting influences SNI usage */
  1657. if(conn->ssl_config.verifyhost) {
  1658. err = SSLSetPeerDomainName(BACKEND->ssl_ctx, hostname,
  1659. strlen(hostname));
  1660. if(err != noErr) {
  1661. infof(data, "WARNING: SSL: SSLSetPeerDomainName() failed: OSStatus %d\n",
  1662. err);
  1663. }
  1664. if((Curl_inet_pton(AF_INET, hostname, &addr))
  1665. #ifdef ENABLE_IPV6
  1666. || (Curl_inet_pton(AF_INET6, hostname, &addr))
  1667. #endif
  1668. ) {
  1669. infof(data, "WARNING: using IP address, SNI is being disabled by "
  1670. "the OS.\n");
  1671. }
  1672. }
  1673. else {
  1674. infof(data, "WARNING: disabling hostname validation also disables SNI.\n");
  1675. }
  1676. /* Disable cipher suites that ST supports but are not safe. These ciphers
  1677. are unlikely to be used in any case since ST gives other ciphers a much
  1678. higher priority, but it's probably better that we not connect at all than
  1679. to give the user a false sense of security if the server only supports
  1680. insecure ciphers. (Note: We don't care about SSLv2-only ciphers.) */
  1681. (void)SSLGetNumberSupportedCiphers(BACKEND->ssl_ctx, &all_ciphers_count);
  1682. all_ciphers = malloc(all_ciphers_count*sizeof(SSLCipherSuite));
  1683. allowed_ciphers = malloc(all_ciphers_count*sizeof(SSLCipherSuite));
  1684. if(all_ciphers && allowed_ciphers &&
  1685. SSLGetSupportedCiphers(BACKEND->ssl_ctx, all_ciphers,
  1686. &all_ciphers_count) == noErr) {
  1687. for(i = 0UL ; i < all_ciphers_count ; i++) {
  1688. #if CURL_BUILD_MAC
  1689. /* There's a known bug in early versions of Mountain Lion where ST's ECC
  1690. ciphers (cipher suite 0xC001 through 0xC032) simply do not work.
  1691. Work around the problem here by disabling those ciphers if we are
  1692. running in an affected version of OS X. */
  1693. if(darwinver_maj == 12 && darwinver_min <= 3 &&
  1694. all_ciphers[i] >= 0xC001 && all_ciphers[i] <= 0xC032) {
  1695. continue;
  1696. }
  1697. #endif /* CURL_BUILD_MAC */
  1698. switch(all_ciphers[i]) {
  1699. /* Disable NULL ciphersuites: */
  1700. case SSL_NULL_WITH_NULL_NULL:
  1701. case SSL_RSA_WITH_NULL_MD5:
  1702. case SSL_RSA_WITH_NULL_SHA:
  1703. case 0x003B: /* TLS_RSA_WITH_NULL_SHA256 */
  1704. case SSL_FORTEZZA_DMS_WITH_NULL_SHA:
  1705. case 0xC001: /* TLS_ECDH_ECDSA_WITH_NULL_SHA */
  1706. case 0xC006: /* TLS_ECDHE_ECDSA_WITH_NULL_SHA */
  1707. case 0xC00B: /* TLS_ECDH_RSA_WITH_NULL_SHA */
  1708. case 0xC010: /* TLS_ECDHE_RSA_WITH_NULL_SHA */
  1709. case 0x002C: /* TLS_PSK_WITH_NULL_SHA */
  1710. case 0x002D: /* TLS_DHE_PSK_WITH_NULL_SHA */
  1711. case 0x002E: /* TLS_RSA_PSK_WITH_NULL_SHA */
  1712. case 0x00B0: /* TLS_PSK_WITH_NULL_SHA256 */
  1713. case 0x00B1: /* TLS_PSK_WITH_NULL_SHA384 */
  1714. case 0x00B4: /* TLS_DHE_PSK_WITH_NULL_SHA256 */
  1715. case 0x00B5: /* TLS_DHE_PSK_WITH_NULL_SHA384 */
  1716. case 0x00B8: /* TLS_RSA_PSK_WITH_NULL_SHA256 */
  1717. case 0x00B9: /* TLS_RSA_PSK_WITH_NULL_SHA384 */
  1718. /* Disable anonymous ciphersuites: */
  1719. case SSL_DH_anon_EXPORT_WITH_RC4_40_MD5:
  1720. case SSL_DH_anon_WITH_RC4_128_MD5:
  1721. case SSL_DH_anon_EXPORT_WITH_DES40_CBC_SHA:
  1722. case SSL_DH_anon_WITH_DES_CBC_SHA:
  1723. case SSL_DH_anon_WITH_3DES_EDE_CBC_SHA:
  1724. case TLS_DH_anon_WITH_AES_128_CBC_SHA:
  1725. case TLS_DH_anon_WITH_AES_256_CBC_SHA:
  1726. case 0xC015: /* TLS_ECDH_anon_WITH_NULL_SHA */
  1727. case 0xC016: /* TLS_ECDH_anon_WITH_RC4_128_SHA */
  1728. case 0xC017: /* TLS_ECDH_anon_WITH_3DES_EDE_CBC_SHA */
  1729. case 0xC018: /* TLS_ECDH_anon_WITH_AES_128_CBC_SHA */
  1730. case 0xC019: /* TLS_ECDH_anon_WITH_AES_256_CBC_SHA */
  1731. case 0x006C: /* TLS_DH_anon_WITH_AES_128_CBC_SHA256 */
  1732. case 0x006D: /* TLS_DH_anon_WITH_AES_256_CBC_SHA256 */
  1733. case 0x00A6: /* TLS_DH_anon_WITH_AES_128_GCM_SHA256 */
  1734. case 0x00A7: /* TLS_DH_anon_WITH_AES_256_GCM_SHA384 */
  1735. /* Disable weak key ciphersuites: */
  1736. case SSL_RSA_EXPORT_WITH_RC4_40_MD5:
  1737. case SSL_RSA_EXPORT_WITH_RC2_CBC_40_MD5:
  1738. case SSL_RSA_EXPORT_WITH_DES40_CBC_SHA:
  1739. case SSL_DH_DSS_EXPORT_WITH_DES40_CBC_SHA:
  1740. case SSL_DH_RSA_EXPORT_WITH_DES40_CBC_SHA:
  1741. case SSL_DHE_DSS_EXPORT_WITH_DES40_CBC_SHA:
  1742. case SSL_DHE_RSA_EXPORT_WITH_DES40_CBC_SHA:
  1743. case SSL_RSA_WITH_DES_CBC_SHA:
  1744. case SSL_DH_DSS_WITH_DES_CBC_SHA:
  1745. case SSL_DH_RSA_WITH_DES_CBC_SHA:
  1746. case SSL_DHE_DSS_WITH_DES_CBC_SHA:
  1747. case SSL_DHE_RSA_WITH_DES_CBC_SHA:
  1748. /* Disable IDEA: */
  1749. case SSL_RSA_WITH_IDEA_CBC_SHA:
  1750. case SSL_RSA_WITH_IDEA_CBC_MD5:
  1751. /* Disable RC4: */
  1752. case SSL_RSA_WITH_RC4_128_MD5:
  1753. case SSL_RSA_WITH_RC4_128_SHA:
  1754. case 0xC002: /* TLS_ECDH_ECDSA_WITH_RC4_128_SHA */
  1755. case 0xC007: /* TLS_ECDHE_ECDSA_WITH_RC4_128_SHA*/
  1756. case 0xC00C: /* TLS_ECDH_RSA_WITH_RC4_128_SHA */
  1757. case 0xC011: /* TLS_ECDHE_RSA_WITH_RC4_128_SHA */
  1758. case 0x008A: /* TLS_PSK_WITH_RC4_128_SHA */
  1759. case 0x008E: /* TLS_DHE_PSK_WITH_RC4_128_SHA */
  1760. case 0x0092: /* TLS_RSA_PSK_WITH_RC4_128_SHA */
  1761. break;
  1762. default: /* enable everything else */
  1763. allowed_ciphers[allowed_ciphers_count++] = all_ciphers[i];
  1764. break;
  1765. }
  1766. }
  1767. err = SSLSetEnabledCiphers(BACKEND->ssl_ctx, allowed_ciphers,
  1768. allowed_ciphers_count);
  1769. if(err != noErr) {
  1770. failf(data, "SSL: SSLSetEnabledCiphers() failed: OSStatus %d", err);
  1771. return CURLE_SSL_CONNECT_ERROR;
  1772. }
  1773. }
  1774. else {
  1775. Curl_safefree(all_ciphers);
  1776. Curl_safefree(allowed_ciphers);
  1777. failf(data, "SSL: Failed to allocate memory for allowed ciphers");
  1778. return CURLE_OUT_OF_MEMORY;
  1779. }
  1780. Curl_safefree(all_ciphers);
  1781. Curl_safefree(allowed_ciphers);
  1782. #if CURL_BUILD_MAC_10_9 || CURL_BUILD_IOS_7
  1783. /* We want to enable 1/n-1 when using a CBC cipher unless the user
  1784. specifically doesn't want us doing that: */
  1785. if(SSLSetSessionOption != NULL) {
  1786. /* TODO s/data->set.ssl.enable_beast/SSL_SET_OPTION(enable_beast)/g */
  1787. SSLSetSessionOption(BACKEND->ssl_ctx, kSSLSessionOptionSendOneByteRecord,
  1788. !data->set.ssl.enable_beast);
  1789. SSLSetSessionOption(BACKEND->ssl_ctx, kSSLSessionOptionFalseStart,
  1790. data->set.ssl.falsestart); /* false start support */
  1791. }
  1792. #endif /* CURL_BUILD_MAC_10_9 || CURL_BUILD_IOS_7 */
  1793. /* Check if there's a cached ID we can/should use here! */
  1794. if(SSL_SET_OPTION(primary.sessionid)) {
  1795. char *ssl_sessionid;
  1796. size_t ssl_sessionid_len;
  1797. Curl_ssl_sessionid_lock(conn);
  1798. if(!Curl_ssl_getsessionid(conn, (void **)&ssl_sessionid,
  1799. &ssl_sessionid_len, sockindex)) {
  1800. /* we got a session id, use it! */
  1801. err = SSLSetPeerID(BACKEND->ssl_ctx, ssl_sessionid, ssl_sessionid_len);
  1802. Curl_ssl_sessionid_unlock(conn);
  1803. if(err != noErr) {
  1804. failf(data, "SSL: SSLSetPeerID() failed: OSStatus %d", err);
  1805. return CURLE_SSL_CONNECT_ERROR;
  1806. }
  1807. /* Informational message */
  1808. infof(data, "SSL re-using session ID\n");
  1809. }
  1810. /* If there isn't one, then let's make one up! This has to be done prior
  1811. to starting the handshake. */
  1812. else {
  1813. CURLcode result;
  1814. ssl_sessionid =
  1815. aprintf("%s:%d:%d:%s:%hu", ssl_cafile,
  1816. verifypeer, SSL_CONN_CONFIG(verifyhost), hostname, port);
  1817. ssl_sessionid_len = strlen(ssl_sessionid);
  1818. err = SSLSetPeerID(BACKEND->ssl_ctx, ssl_sessionid, ssl_sessionid_len);
  1819. if(err != noErr) {
  1820. Curl_ssl_sessionid_unlock(conn);
  1821. failf(data, "SSL: SSLSetPeerID() failed: OSStatus %d", err);
  1822. return CURLE_SSL_CONNECT_ERROR;
  1823. }
  1824. result = Curl_ssl_addsessionid(conn, ssl_sessionid, ssl_sessionid_len,
  1825. sockindex);
  1826. Curl_ssl_sessionid_unlock(conn);
  1827. if(result) {
  1828. failf(data, "failed to store ssl session");
  1829. return result;
  1830. }
  1831. }
  1832. }
  1833. err = SSLSetIOFuncs(BACKEND->ssl_ctx, SocketRead, SocketWrite);
  1834. if(err != noErr) {
  1835. failf(data, "SSL: SSLSetIOFuncs() failed: OSStatus %d", err);
  1836. return CURLE_SSL_CONNECT_ERROR;
  1837. }
  1838. /* pass the raw socket into the SSL layers */
  1839. /* We need to store the FD in a constant memory address, because
  1840. * SSLSetConnection() will not copy that address. I've found that
  1841. * conn->sock[sockindex] may change on its own. */
  1842. BACKEND->ssl_sockfd = sockfd;
  1843. err = SSLSetConnection(BACKEND->ssl_ctx, connssl);
  1844. if(err != noErr) {
  1845. failf(data, "SSL: SSLSetConnection() failed: %d", err);
  1846. return CURLE_SSL_CONNECT_ERROR;
  1847. }
  1848. connssl->connecting_state = ssl_connect_2;
  1849. return CURLE_OK;
  1850. }
  1851. static long pem_to_der(const char *in, unsigned char **out, size_t *outlen)
  1852. {
  1853. char *sep_start, *sep_end, *cert_start, *cert_end;
  1854. size_t i, j, err;
  1855. size_t len;
  1856. unsigned char *b64;
  1857. /* Jump through the separators at the beginning of the certificate. */
  1858. sep_start = strstr(in, "-----");
  1859. if(sep_start == NULL)
  1860. return 0;
  1861. cert_start = strstr(sep_start + 1, "-----");
  1862. if(cert_start == NULL)
  1863. return -1;
  1864. cert_start += 5;
  1865. /* Find separator after the end of the certificate. */
  1866. cert_end = strstr(cert_start, "-----");
  1867. if(cert_end == NULL)
  1868. return -1;
  1869. sep_end = strstr(cert_end + 1, "-----");
  1870. if(sep_end == NULL)
  1871. return -1;
  1872. sep_end += 5;
  1873. len = cert_end - cert_start;
  1874. b64 = malloc(len + 1);
  1875. if(!b64)
  1876. return -1;
  1877. /* Create base64 string without linefeeds. */
  1878. for(i = 0, j = 0; i < len; i++) {
  1879. if(cert_start[i] != '\r' && cert_start[i] != '\n')
  1880. b64[j++] = cert_start[i];
  1881. }
  1882. b64[j] = '\0';
  1883. err = Curl_base64_decode((const char *)b64, out, outlen);
  1884. free(b64);
  1885. if(err) {
  1886. free(*out);
  1887. return -1;
  1888. }
  1889. return sep_end - in;
  1890. }
  1891. static int read_cert(const char *file, unsigned char **out, size_t *outlen)
  1892. {
  1893. int fd;
  1894. ssize_t n, len = 0, cap = 512;
  1895. unsigned char buf[512], *data;
  1896. fd = open(file, 0);
  1897. if(fd < 0)
  1898. return -1;
  1899. data = malloc(cap);
  1900. if(!data) {
  1901. close(fd);
  1902. return -1;
  1903. }
  1904. for(;;) {
  1905. n = read(fd, buf, sizeof(buf));
  1906. if(n < 0) {
  1907. close(fd);
  1908. free(data);
  1909. return -1;
  1910. }
  1911. else if(n == 0) {
  1912. close(fd);
  1913. break;
  1914. }
  1915. if(len + n >= cap) {
  1916. cap *= 2;
  1917. data = realloc(data, cap);
  1918. if(!data) {
  1919. close(fd);
  1920. return -1;
  1921. }
  1922. }
  1923. memcpy(data + len, buf, n);
  1924. len += n;
  1925. }
  1926. data[len] = '\0';
  1927. *out = data;
  1928. *outlen = len;
  1929. return 0;
  1930. }
  1931. static int sslerr_to_curlerr(struct Curl_easy *data, int err)
  1932. {
  1933. switch(err) {
  1934. case errSSLXCertChainInvalid:
  1935. failf(data, "SSL certificate problem: Invalid certificate chain");
  1936. return CURLE_SSL_CACERT;
  1937. case errSSLUnknownRootCert:
  1938. failf(data, "SSL certificate problem: Untrusted root certificate");
  1939. return CURLE_SSL_CACERT;
  1940. case errSSLNoRootCert:
  1941. failf(data, "SSL certificate problem: No root certificate");
  1942. return CURLE_SSL_CACERT;
  1943. case errSSLCertExpired:
  1944. failf(data, "SSL certificate problem: Certificate chain had an "
  1945. "expired certificate");
  1946. return CURLE_SSL_CACERT;
  1947. case errSSLBadCert:
  1948. failf(data, "SSL certificate problem: Couldn't understand the server "
  1949. "certificate format");
  1950. return CURLE_SSL_CONNECT_ERROR;
  1951. case errSSLHostNameMismatch:
  1952. failf(data, "SSL certificate peer hostname mismatch");
  1953. return CURLE_PEER_FAILED_VERIFICATION;
  1954. default:
  1955. failf(data, "SSL unexpected certificate error %d", err);
  1956. return CURLE_SSL_CACERT;
  1957. }
  1958. }
  1959. static int append_cert_to_array(struct Curl_easy *data,
  1960. unsigned char *buf, size_t buflen,
  1961. CFMutableArrayRef array)
  1962. {
  1963. CFDataRef certdata = CFDataCreate(kCFAllocatorDefault, buf, buflen);
  1964. char *certp;
  1965. CURLcode result;
  1966. if(!certdata) {
  1967. failf(data, "SSL: failed to allocate array for CA certificate");
  1968. return CURLE_OUT_OF_MEMORY;
  1969. }
  1970. SecCertificateRef cacert =
  1971. SecCertificateCreateWithData(kCFAllocatorDefault, certdata);
  1972. CFRelease(certdata);
  1973. if(!cacert) {
  1974. failf(data, "SSL: failed to create SecCertificate from CA certificate");
  1975. return CURLE_SSL_CACERT;
  1976. }
  1977. /* Check if cacert is valid. */
  1978. result = CopyCertSubject(data, cacert, &certp);
  1979. if(result)
  1980. return result;
  1981. free(certp);
  1982. CFArrayAppendValue(array, cacert);
  1983. CFRelease(cacert);
  1984. return CURLE_OK;
  1985. }
  1986. static int verify_cert(const char *cafile, struct Curl_easy *data,
  1987. SSLContextRef ctx)
  1988. {
  1989. int n = 0, rc;
  1990. long res;
  1991. unsigned char *certbuf, *der;
  1992. size_t buflen, derlen, offset = 0;
  1993. if(read_cert(cafile, &certbuf, &buflen) < 0) {
  1994. failf(data, "SSL: failed to read or invalid CA certificate");
  1995. return CURLE_SSL_CACERT;
  1996. }
  1997. /*
  1998. * Certbuf now contains the contents of the certificate file, which can be
  1999. * - a single DER certificate,
  2000. * - a single PEM certificate or
  2001. * - a bunch of PEM certificates (certificate bundle).
  2002. *
  2003. * Go through certbuf, and convert any PEM certificate in it into DER
  2004. * format.
  2005. */
  2006. CFMutableArrayRef array = CFArrayCreateMutable(kCFAllocatorDefault, 0,
  2007. &kCFTypeArrayCallBacks);
  2008. if(array == NULL) {
  2009. free(certbuf);
  2010. failf(data, "SSL: out of memory creating CA certificate array");
  2011. return CURLE_OUT_OF_MEMORY;
  2012. }
  2013. while(offset < buflen) {
  2014. n++;
  2015. /*
  2016. * Check if the certificate is in PEM format, and convert it to DER. If
  2017. * this fails, we assume the certificate is in DER format.
  2018. */
  2019. res = pem_to_der((const char *)certbuf + offset, &der, &derlen);
  2020. if(res < 0) {
  2021. free(certbuf);
  2022. CFRelease(array);
  2023. failf(data, "SSL: invalid CA certificate #%d (offset %d) in bundle",
  2024. n, offset);
  2025. return CURLE_SSL_CACERT;
  2026. }
  2027. offset += res;
  2028. if(res == 0 && offset == 0) {
  2029. /* This is not a PEM file, probably a certificate in DER format. */
  2030. rc = append_cert_to_array(data, certbuf, buflen, array);
  2031. free(certbuf);
  2032. if(rc != CURLE_OK) {
  2033. CFRelease(array);
  2034. return rc;
  2035. }
  2036. break;
  2037. }
  2038. else if(res == 0) {
  2039. /* No more certificates in the bundle. */
  2040. free(certbuf);
  2041. break;
  2042. }
  2043. rc = append_cert_to_array(data, der, derlen, array);
  2044. free(der);
  2045. if(rc != CURLE_OK) {
  2046. free(certbuf);
  2047. CFRelease(array);
  2048. return rc;
  2049. }
  2050. }
  2051. SecTrustRef trust;
  2052. OSStatus ret = SSLCopyPeerTrust(ctx, &trust);
  2053. if(trust == NULL) {
  2054. failf(data, "SSL: error getting certificate chain");
  2055. CFRelease(array);
  2056. return CURLE_OUT_OF_MEMORY;
  2057. }
  2058. else if(ret != noErr) {
  2059. CFRelease(array);
  2060. return sslerr_to_curlerr(data, ret);
  2061. }
  2062. ret = SecTrustSetAnchorCertificates(trust, array);
  2063. if(ret != noErr) {
  2064. CFRelease(trust);
  2065. return sslerr_to_curlerr(data, ret);
  2066. }
  2067. ret = SecTrustSetAnchorCertificatesOnly(trust, true);
  2068. if(ret != noErr) {
  2069. CFRelease(trust);
  2070. return sslerr_to_curlerr(data, ret);
  2071. }
  2072. SecTrustResultType trust_eval = 0;
  2073. ret = SecTrustEvaluate(trust, &trust_eval);
  2074. CFRelease(array);
  2075. CFRelease(trust);
  2076. if(ret != noErr) {
  2077. return sslerr_to_curlerr(data, ret);
  2078. }
  2079. switch(trust_eval) {
  2080. case kSecTrustResultUnspecified:
  2081. case kSecTrustResultProceed:
  2082. return CURLE_OK;
  2083. case kSecTrustResultRecoverableTrustFailure:
  2084. case kSecTrustResultDeny:
  2085. default:
  2086. failf(data, "SSL: certificate verification failed (result: %d)",
  2087. trust_eval);
  2088. return CURLE_PEER_FAILED_VERIFICATION;
  2089. }
  2090. }
  2091. #ifdef DARWIN_SSL_PINNEDPUBKEY
  2092. static CURLcode pkp_pin_peer_pubkey(struct Curl_easy *data,
  2093. SSLContextRef ctx,
  2094. const char *pinnedpubkey)
  2095. { /* Scratch */
  2096. size_t pubkeylen, realpubkeylen, spkiHeaderLength = 24;
  2097. unsigned char *pubkey = NULL, *realpubkey = NULL;
  2098. const unsigned char *spkiHeader = NULL;
  2099. CFDataRef publicKeyBits = NULL;
  2100. /* Result is returned to caller */
  2101. CURLcode result = CURLE_SSL_PINNEDPUBKEYNOTMATCH;
  2102. /* if a path wasn't specified, don't pin */
  2103. if(!pinnedpubkey)
  2104. return CURLE_OK;
  2105. if(!ctx)
  2106. return result;
  2107. do {
  2108. SecTrustRef trust;
  2109. OSStatus ret = SSLCopyPeerTrust(ctx, &trust);
  2110. if(ret != noErr || trust == NULL)
  2111. break;
  2112. SecKeyRef keyRef = SecTrustCopyPublicKey(trust);
  2113. CFRelease(trust);
  2114. if(keyRef == NULL)
  2115. break;
  2116. #ifdef DARWIN_SSL_PINNEDPUBKEY_V1
  2117. publicKeyBits = SecKeyCopyExternalRepresentation(keyRef, NULL);
  2118. CFRelease(keyRef);
  2119. if(publicKeyBits == NULL)
  2120. break;
  2121. #elif DARWIN_SSL_PINNEDPUBKEY_V2
  2122. OSStatus success = SecItemExport(keyRef, kSecFormatOpenSSL, 0, NULL,
  2123. &publicKeyBits);
  2124. CFRelease(keyRef);
  2125. if(success != errSecSuccess || publicKeyBits == NULL)
  2126. break;
  2127. #endif /* DARWIN_SSL_PINNEDPUBKEY_V2 */
  2128. pubkeylen = CFDataGetLength(publicKeyBits);
  2129. pubkey = (unsigned char *)CFDataGetBytePtr(publicKeyBits);
  2130. switch(pubkeylen) {
  2131. case 526:
  2132. /* 4096 bit RSA pubkeylen == 526 */
  2133. spkiHeader = rsa4096SpkiHeader;
  2134. break;
  2135. case 270:
  2136. /* 2048 bit RSA pubkeylen == 270 */
  2137. spkiHeader = rsa2048SpkiHeader;
  2138. break;
  2139. #ifdef DARWIN_SSL_PINNEDPUBKEY_V1
  2140. case 65:
  2141. /* ecDSA secp256r1 pubkeylen == 65 */
  2142. spkiHeader = ecDsaSecp256r1SpkiHeader;
  2143. spkiHeaderLength = 26;
  2144. break;
  2145. case 97:
  2146. /* ecDSA secp384r1 pubkeylen == 97 */
  2147. spkiHeader = ecDsaSecp384r1SpkiHeader;
  2148. spkiHeaderLength = 23;
  2149. break;
  2150. default:
  2151. infof(data, "SSL: unhandled public key length: %d\n", pubkeylen);
  2152. #elif DARWIN_SSL_PINNEDPUBKEY_V2
  2153. default:
  2154. /* ecDSA secp256r1 pubkeylen == 91 header already included?
  2155. * ecDSA secp384r1 header already included too
  2156. * we assume rest of algorithms do same, so do nothing
  2157. */
  2158. result = Curl_pin_peer_pubkey(data, pinnedpubkey, pubkey,
  2159. pubkeylen);
  2160. #endif /* DARWIN_SSL_PINNEDPUBKEY_V2 */
  2161. continue; /* break from loop */
  2162. }
  2163. realpubkeylen = pubkeylen + spkiHeaderLength;
  2164. realpubkey = malloc(realpubkeylen);
  2165. if(!realpubkey)
  2166. break;
  2167. memcpy(realpubkey, spkiHeader, spkiHeaderLength);
  2168. memcpy(realpubkey + spkiHeaderLength, pubkey, pubkeylen);
  2169. result = Curl_pin_peer_pubkey(data, pinnedpubkey, realpubkey,
  2170. realpubkeylen);
  2171. } while(0);
  2172. Curl_safefree(realpubkey);
  2173. if(publicKeyBits != NULL)
  2174. CFRelease(publicKeyBits);
  2175. return result;
  2176. }
  2177. #endif /* DARWIN_SSL_PINNEDPUBKEY */
  2178. static CURLcode
  2179. darwinssl_connect_step2(struct connectdata *conn, int sockindex)
  2180. {
  2181. struct Curl_easy *data = conn->data;
  2182. struct ssl_connect_data *connssl = &conn->ssl[sockindex];
  2183. OSStatus err;
  2184. SSLCipherSuite cipher;
  2185. SSLProtocol protocol = 0;
  2186. const char * const hostname = SSL_IS_PROXY() ? conn->http_proxy.host.name :
  2187. conn->host.name;
  2188. DEBUGASSERT(ssl_connect_2 == connssl->connecting_state
  2189. || ssl_connect_2_reading == connssl->connecting_state
  2190. || ssl_connect_2_writing == connssl->connecting_state);
  2191. /* Here goes nothing: */
  2192. err = SSLHandshake(BACKEND->ssl_ctx);
  2193. if(err != noErr) {
  2194. switch(err) {
  2195. case errSSLWouldBlock: /* they're not done with us yet */
  2196. connssl->connecting_state = BACKEND->ssl_direction ?
  2197. ssl_connect_2_writing : ssl_connect_2_reading;
  2198. return CURLE_OK;
  2199. /* The below is errSSLServerAuthCompleted; it's not defined in
  2200. Leopard's headers */
  2201. case -9841:
  2202. if(SSL_CONN_CONFIG(CAfile) && SSL_CONN_CONFIG(verifypeer)) {
  2203. int res = verify_cert(SSL_CONN_CONFIG(CAfile), data,
  2204. BACKEND->ssl_ctx);
  2205. if(res != CURLE_OK)
  2206. return res;
  2207. }
  2208. /* the documentation says we need to call SSLHandshake() again */
  2209. return darwinssl_connect_step2(conn, sockindex);
  2210. /* These are all certificate problems with the server: */
  2211. case errSSLXCertChainInvalid:
  2212. failf(data, "SSL certificate problem: Invalid certificate chain");
  2213. return CURLE_SSL_CACERT;
  2214. case errSSLUnknownRootCert:
  2215. failf(data, "SSL certificate problem: Untrusted root certificate");
  2216. return CURLE_SSL_CACERT;
  2217. case errSSLNoRootCert:
  2218. failf(data, "SSL certificate problem: No root certificate");
  2219. return CURLE_SSL_CACERT;
  2220. case errSSLCertExpired:
  2221. failf(data, "SSL certificate problem: Certificate chain had an "
  2222. "expired certificate");
  2223. return CURLE_SSL_CACERT;
  2224. case errSSLBadCert:
  2225. failf(data, "SSL certificate problem: Couldn't understand the server "
  2226. "certificate format");
  2227. return CURLE_SSL_CONNECT_ERROR;
  2228. /* These are all certificate problems with the client: */
  2229. case errSecAuthFailed:
  2230. failf(data, "SSL authentication failed");
  2231. return CURLE_SSL_CONNECT_ERROR;
  2232. case errSSLPeerHandshakeFail:
  2233. failf(data, "SSL peer handshake failed, the server most likely "
  2234. "requires a client certificate to connect");
  2235. return CURLE_SSL_CONNECT_ERROR;
  2236. case errSSLPeerUnknownCA:
  2237. failf(data, "SSL server rejected the client certificate due to "
  2238. "the certificate being signed by an unknown certificate "
  2239. "authority");
  2240. return CURLE_SSL_CONNECT_ERROR;
  2241. /* This error is raised if the server's cert didn't match the server's
  2242. host name: */
  2243. case errSSLHostNameMismatch:
  2244. failf(data, "SSL certificate peer verification failed, the "
  2245. "certificate did not match \"%s\"\n", conn->host.dispname);
  2246. return CURLE_PEER_FAILED_VERIFICATION;
  2247. /* Generic handshake errors: */
  2248. case errSSLConnectionRefused:
  2249. failf(data, "Server dropped the connection during the SSL handshake");
  2250. return CURLE_SSL_CONNECT_ERROR;
  2251. case errSSLClosedAbort:
  2252. failf(data, "Server aborted the SSL handshake");
  2253. return CURLE_SSL_CONNECT_ERROR;
  2254. case errSSLNegotiation:
  2255. failf(data, "Could not negotiate an SSL cipher suite with the server");
  2256. return CURLE_SSL_CONNECT_ERROR;
  2257. /* Sometimes paramErr happens with buggy ciphers: */
  2258. case paramErr: case errSSLInternal:
  2259. failf(data, "Internal SSL engine error encountered during the "
  2260. "SSL handshake");
  2261. return CURLE_SSL_CONNECT_ERROR;
  2262. case errSSLFatalAlert:
  2263. failf(data, "Fatal SSL engine error encountered during the SSL "
  2264. "handshake");
  2265. return CURLE_SSL_CONNECT_ERROR;
  2266. default:
  2267. failf(data, "Unknown SSL protocol error in connection to %s:%d",
  2268. hostname, err);
  2269. return CURLE_SSL_CONNECT_ERROR;
  2270. }
  2271. }
  2272. else {
  2273. /* we have been connected fine, we're not waiting for anything else. */
  2274. connssl->connecting_state = ssl_connect_3;
  2275. #ifdef DARWIN_SSL_PINNEDPUBKEY
  2276. if(data->set.str[STRING_SSL_PINNEDPUBLICKEY_ORIG]) {
  2277. CURLcode result = pkp_pin_peer_pubkey(data, BACKEND->ssl_ctx,
  2278. data->set.str[STRING_SSL_PINNEDPUBLICKEY_ORIG]);
  2279. if(result) {
  2280. failf(data, "SSL: public key does not match pinned public key!");
  2281. return result;
  2282. }
  2283. }
  2284. #endif /* DARWIN_SSL_PINNEDPUBKEY */
  2285. /* Informational message */
  2286. (void)SSLGetNegotiatedCipher(BACKEND->ssl_ctx, &cipher);
  2287. (void)SSLGetNegotiatedProtocolVersion(BACKEND->ssl_ctx, &protocol);
  2288. switch(protocol) {
  2289. case kSSLProtocol2:
  2290. infof(data, "SSL 2.0 connection using %s\n",
  2291. SSLCipherNameForNumber(cipher));
  2292. break;
  2293. case kSSLProtocol3:
  2294. infof(data, "SSL 3.0 connection using %s\n",
  2295. SSLCipherNameForNumber(cipher));
  2296. break;
  2297. case kTLSProtocol1:
  2298. infof(data, "TLS 1.0 connection using %s\n",
  2299. TLSCipherNameForNumber(cipher));
  2300. break;
  2301. #if CURL_BUILD_MAC_10_8 || CURL_BUILD_IOS
  2302. case kTLSProtocol11:
  2303. infof(data, "TLS 1.1 connection using %s\n",
  2304. TLSCipherNameForNumber(cipher));
  2305. break;
  2306. case kTLSProtocol12:
  2307. infof(data, "TLS 1.2 connection using %s\n",
  2308. TLSCipherNameForNumber(cipher));
  2309. break;
  2310. #endif /* CURL_BUILD_MAC_10_8 || CURL_BUILD_IOS */
  2311. #if CURL_BUILD_MAC_10_13 || CURL_BUILD_IOS_11
  2312. case kTLSProtocol13:
  2313. infof(data, "TLS 1.3 connection using %s\n",
  2314. TLSCipherNameForNumber(cipher));
  2315. break;
  2316. #endif /* CURL_BUILD_MAC_10_13 || CURL_BUILD_IOS_11 */
  2317. default:
  2318. infof(data, "Unknown protocol connection\n");
  2319. break;
  2320. }
  2321. #if(CURL_BUILD_MAC_10_13 || CURL_BUILD_IOS_11) && HAVE_BUILTIN_AVAILABLE == 1
  2322. if(conn->bits.tls_enable_alpn) {
  2323. if(__builtin_available(macOS 10.13.4, iOS 11, *)) {
  2324. CFArrayRef alpnArr = NULL;
  2325. CFStringRef chosenProtocol = NULL;
  2326. err = SSLCopyALPNProtocols(BACKEND->ssl_ctx, &alpnArr);
  2327. if(err == noErr && alpnArr && CFArrayGetCount(alpnArr) >= 1)
  2328. chosenProtocol = CFArrayGetValueAtIndex(alpnArr, 0);
  2329. #ifdef USE_NGHTTP2
  2330. if(chosenProtocol &&
  2331. !CFStringCompare(chosenProtocol, CFSTR(NGHTTP2_PROTO_VERSION_ID),
  2332. 0)) {
  2333. conn->negnpn = CURL_HTTP_VERSION_2;
  2334. }
  2335. else
  2336. #endif
  2337. if(chosenProtocol &&
  2338. !CFStringCompare(chosenProtocol, CFSTR(ALPN_HTTP_1_1), 0)) {
  2339. conn->negnpn = CURL_HTTP_VERSION_1_1;
  2340. }
  2341. else
  2342. infof(data, "ALPN, server did not agree to a protocol\n");
  2343. /* chosenProtocol is a reference to the string within alpnArr
  2344. and doesn't need to be freed separately */
  2345. if(alpnArr)
  2346. CFRelease(alpnArr);
  2347. }
  2348. }
  2349. #endif
  2350. return CURLE_OK;
  2351. }
  2352. }
  2353. #ifndef CURL_DISABLE_VERBOSE_STRINGS
  2354. /* This should be called during step3 of the connection at the earliest */
  2355. static void
  2356. show_verbose_server_cert(struct connectdata *conn,
  2357. int sockindex)
  2358. {
  2359. struct Curl_easy *data = conn->data;
  2360. struct ssl_connect_data *connssl = &conn->ssl[sockindex];
  2361. CFArrayRef server_certs = NULL;
  2362. SecCertificateRef server_cert;
  2363. OSStatus err;
  2364. CFIndex i, count;
  2365. SecTrustRef trust = NULL;
  2366. if(!BACKEND->ssl_ctx)
  2367. return;
  2368. #if CURL_BUILD_MAC_10_7 || CURL_BUILD_IOS
  2369. #if CURL_BUILD_IOS
  2370. #pragma unused(server_certs)
  2371. err = SSLCopyPeerTrust(BACKEND->ssl_ctx, &trust);
  2372. /* For some reason, SSLCopyPeerTrust() can return noErr and yet return
  2373. a null trust, so be on guard for that: */
  2374. if(err == noErr && trust) {
  2375. count = SecTrustGetCertificateCount(trust);
  2376. for(i = 0L ; i < count ; i++) {
  2377. CURLcode result;
  2378. char *certp;
  2379. server_cert = SecTrustGetCertificateAtIndex(trust, i);
  2380. result = CopyCertSubject(data, server_cert, &certp);
  2381. if(!result) {
  2382. infof(data, "Server certificate: %s\n", certp);
  2383. free(certp);
  2384. }
  2385. }
  2386. CFRelease(trust);
  2387. }
  2388. #else
  2389. /* SSLCopyPeerCertificates() is deprecated as of Mountain Lion.
  2390. The function SecTrustGetCertificateAtIndex() is officially present
  2391. in Lion, but it is unfortunately also present in Snow Leopard as
  2392. private API and doesn't work as expected. So we have to look for
  2393. a different symbol to make sure this code is only executed under
  2394. Lion or later. */
  2395. if(SecTrustEvaluateAsync != NULL) {
  2396. #pragma unused(server_certs)
  2397. err = SSLCopyPeerTrust(BACKEND->ssl_ctx, &trust);
  2398. /* For some reason, SSLCopyPeerTrust() can return noErr and yet return
  2399. a null trust, so be on guard for that: */
  2400. if(err == noErr && trust) {
  2401. count = SecTrustGetCertificateCount(trust);
  2402. for(i = 0L ; i < count ; i++) {
  2403. char *certp;
  2404. CURLcode result;
  2405. server_cert = SecTrustGetCertificateAtIndex(trust, i);
  2406. result = CopyCertSubject(data, server_cert, &certp);
  2407. if(!result) {
  2408. infof(data, "Server certificate: %s\n", certp);
  2409. free(certp);
  2410. }
  2411. }
  2412. CFRelease(trust);
  2413. }
  2414. }
  2415. else {
  2416. #if CURL_SUPPORT_MAC_10_8
  2417. err = SSLCopyPeerCertificates(BACKEND->ssl_ctx, &server_certs);
  2418. /* Just in case SSLCopyPeerCertificates() returns null too... */
  2419. if(err == noErr && server_certs) {
  2420. count = CFArrayGetCount(server_certs);
  2421. for(i = 0L ; i < count ; i++) {
  2422. char *certp;
  2423. CURLcode result;
  2424. server_cert = (SecCertificateRef)CFArrayGetValueAtIndex(server_certs,
  2425. i);
  2426. result = CopyCertSubject(data, server_cert, &certp);
  2427. if(!result) {
  2428. infof(data, "Server certificate: %s\n", certp);
  2429. free(certp);
  2430. }
  2431. }
  2432. CFRelease(server_certs);
  2433. }
  2434. #endif /* CURL_SUPPORT_MAC_10_8 */
  2435. }
  2436. #endif /* CURL_BUILD_IOS */
  2437. #else
  2438. #pragma unused(trust)
  2439. err = SSLCopyPeerCertificates(BACKEND->ssl_ctx, &server_certs);
  2440. if(err == noErr) {
  2441. count = CFArrayGetCount(server_certs);
  2442. for(i = 0L ; i < count ; i++) {
  2443. CURLcode result;
  2444. char *certp;
  2445. server_cert = (SecCertificateRef)CFArrayGetValueAtIndex(server_certs, i);
  2446. result = CopyCertSubject(data, server_cert, &certp);
  2447. if(!result) {
  2448. infof(data, "Server certificate: %s\n", certp);
  2449. free(certp);
  2450. }
  2451. }
  2452. CFRelease(server_certs);
  2453. }
  2454. #endif /* CURL_BUILD_MAC_10_7 || CURL_BUILD_IOS */
  2455. }
  2456. #endif /* !CURL_DISABLE_VERBOSE_STRINGS */
  2457. static CURLcode
  2458. darwinssl_connect_step3(struct connectdata *conn,
  2459. int sockindex)
  2460. {
  2461. struct Curl_easy *data = conn->data;
  2462. struct ssl_connect_data *connssl = &conn->ssl[sockindex];
  2463. /* There is no step 3!
  2464. * Well, okay, if verbose mode is on, let's print the details of the
  2465. * server certificates. */
  2466. #ifndef CURL_DISABLE_VERBOSE_STRINGS
  2467. if(data->set.verbose)
  2468. show_verbose_server_cert(conn, sockindex);
  2469. #endif
  2470. connssl->connecting_state = ssl_connect_done;
  2471. return CURLE_OK;
  2472. }
  2473. static Curl_recv darwinssl_recv;
  2474. static Curl_send darwinssl_send;
  2475. static CURLcode
  2476. darwinssl_connect_common(struct connectdata *conn,
  2477. int sockindex,
  2478. bool nonblocking,
  2479. bool *done)
  2480. {
  2481. CURLcode result;
  2482. struct Curl_easy *data = conn->data;
  2483. struct ssl_connect_data *connssl = &conn->ssl[sockindex];
  2484. curl_socket_t sockfd = conn->sock[sockindex];
  2485. long timeout_ms;
  2486. int what;
  2487. /* check if the connection has already been established */
  2488. if(ssl_connection_complete == connssl->state) {
  2489. *done = TRUE;
  2490. return CURLE_OK;
  2491. }
  2492. if(ssl_connect_1 == connssl->connecting_state) {
  2493. /* Find out how much more time we're allowed */
  2494. timeout_ms = Curl_timeleft(data, NULL, TRUE);
  2495. if(timeout_ms < 0) {
  2496. /* no need to continue if time already is up */
  2497. failf(data, "SSL connection timeout");
  2498. return CURLE_OPERATION_TIMEDOUT;
  2499. }
  2500. result = darwinssl_connect_step1(conn, sockindex);
  2501. if(result)
  2502. return result;
  2503. }
  2504. while(ssl_connect_2 == connssl->connecting_state ||
  2505. ssl_connect_2_reading == connssl->connecting_state ||
  2506. ssl_connect_2_writing == connssl->connecting_state) {
  2507. /* check allowed time left */
  2508. timeout_ms = Curl_timeleft(data, NULL, TRUE);
  2509. if(timeout_ms < 0) {
  2510. /* no need to continue if time already is up */
  2511. failf(data, "SSL connection timeout");
  2512. return CURLE_OPERATION_TIMEDOUT;
  2513. }
  2514. /* if ssl is expecting something, check if it's available. */
  2515. if(connssl->connecting_state == ssl_connect_2_reading ||
  2516. connssl->connecting_state == ssl_connect_2_writing) {
  2517. curl_socket_t writefd = ssl_connect_2_writing ==
  2518. connssl->connecting_state?sockfd:CURL_SOCKET_BAD;
  2519. curl_socket_t readfd = ssl_connect_2_reading ==
  2520. connssl->connecting_state?sockfd:CURL_SOCKET_BAD;
  2521. what = Curl_socket_check(readfd, CURL_SOCKET_BAD, writefd,
  2522. nonblocking?0:timeout_ms);
  2523. if(what < 0) {
  2524. /* fatal error */
  2525. failf(data, "select/poll on SSL socket, errno: %d", SOCKERRNO);
  2526. return CURLE_SSL_CONNECT_ERROR;
  2527. }
  2528. else if(0 == what) {
  2529. if(nonblocking) {
  2530. *done = FALSE;
  2531. return CURLE_OK;
  2532. }
  2533. else {
  2534. /* timeout */
  2535. failf(data, "SSL connection timeout");
  2536. return CURLE_OPERATION_TIMEDOUT;
  2537. }
  2538. }
  2539. /* socket is readable or writable */
  2540. }
  2541. /* Run transaction, and return to the caller if it failed or if this
  2542. * connection is done nonblocking and this loop would execute again. This
  2543. * permits the owner of a multi handle to abort a connection attempt
  2544. * before step2 has completed while ensuring that a client using select()
  2545. * or epoll() will always have a valid fdset to wait on.
  2546. */
  2547. result = darwinssl_connect_step2(conn, sockindex);
  2548. if(result || (nonblocking &&
  2549. (ssl_connect_2 == connssl->connecting_state ||
  2550. ssl_connect_2_reading == connssl->connecting_state ||
  2551. ssl_connect_2_writing == connssl->connecting_state)))
  2552. return result;
  2553. } /* repeat step2 until all transactions are done. */
  2554. if(ssl_connect_3 == connssl->connecting_state) {
  2555. result = darwinssl_connect_step3(conn, sockindex);
  2556. if(result)
  2557. return result;
  2558. }
  2559. if(ssl_connect_done == connssl->connecting_state) {
  2560. connssl->state = ssl_connection_complete;
  2561. conn->recv[sockindex] = darwinssl_recv;
  2562. conn->send[sockindex] = darwinssl_send;
  2563. *done = TRUE;
  2564. }
  2565. else
  2566. *done = FALSE;
  2567. /* Reset our connect state machine */
  2568. connssl->connecting_state = ssl_connect_1;
  2569. return CURLE_OK;
  2570. }
  2571. static CURLcode Curl_darwinssl_connect_nonblocking(struct connectdata *conn,
  2572. int sockindex, bool *done)
  2573. {
  2574. return darwinssl_connect_common(conn, sockindex, TRUE, done);
  2575. }
  2576. static CURLcode Curl_darwinssl_connect(struct connectdata *conn, int sockindex)
  2577. {
  2578. CURLcode result;
  2579. bool done = FALSE;
  2580. result = darwinssl_connect_common(conn, sockindex, FALSE, &done);
  2581. if(result)
  2582. return result;
  2583. DEBUGASSERT(done);
  2584. return CURLE_OK;
  2585. }
  2586. static void Curl_darwinssl_close(struct connectdata *conn, int sockindex)
  2587. {
  2588. struct ssl_connect_data *connssl = &conn->ssl[sockindex];
  2589. if(BACKEND->ssl_ctx) {
  2590. (void)SSLClose(BACKEND->ssl_ctx);
  2591. #if CURL_BUILD_MAC_10_8 || CURL_BUILD_IOS
  2592. if(SSLCreateContext != NULL)
  2593. CFRelease(BACKEND->ssl_ctx);
  2594. #if CURL_SUPPORT_MAC_10_8
  2595. else
  2596. (void)SSLDisposeContext(BACKEND->ssl_ctx);
  2597. #endif /* CURL_SUPPORT_MAC_10_8 */
  2598. #else
  2599. (void)SSLDisposeContext(BACKEND->ssl_ctx);
  2600. #endif /* CURL_BUILD_MAC_10_8 || CURL_BUILD_IOS */
  2601. BACKEND->ssl_ctx = NULL;
  2602. }
  2603. BACKEND->ssl_sockfd = 0;
  2604. }
  2605. static int Curl_darwinssl_shutdown(struct connectdata *conn, int sockindex)
  2606. {
  2607. struct ssl_connect_data *connssl = &conn->ssl[sockindex];
  2608. struct Curl_easy *data = conn->data;
  2609. ssize_t nread;
  2610. int what;
  2611. int rc;
  2612. char buf[120];
  2613. if(!BACKEND->ssl_ctx)
  2614. return 0;
  2615. if(data->set.ftp_ccc != CURLFTPSSL_CCC_ACTIVE)
  2616. return 0;
  2617. Curl_darwinssl_close(conn, sockindex);
  2618. rc = 0;
  2619. what = SOCKET_READABLE(conn->sock[sockindex], SSL_SHUTDOWN_TIMEOUT);
  2620. for(;;) {
  2621. if(what < 0) {
  2622. /* anything that gets here is fatally bad */
  2623. failf(data, "select/poll on SSL socket, errno: %d", SOCKERRNO);
  2624. rc = -1;
  2625. break;
  2626. }
  2627. if(!what) { /* timeout */
  2628. failf(data, "SSL shutdown timeout");
  2629. break;
  2630. }
  2631. /* Something to read, let's do it and hope that it is the close
  2632. notify alert from the server. No way to SSL_Read now, so use read(). */
  2633. nread = read(conn->sock[sockindex], buf, sizeof(buf));
  2634. if(nread < 0) {
  2635. failf(data, "read: %s", strerror(errno));
  2636. rc = -1;
  2637. }
  2638. if(nread <= 0)
  2639. break;
  2640. what = SOCKET_READABLE(conn->sock[sockindex], 0);
  2641. }
  2642. return rc;
  2643. }
  2644. static void Curl_darwinssl_session_free(void *ptr)
  2645. {
  2646. /* ST, as of iOS 5 and Mountain Lion, has no public method of deleting a
  2647. cached session ID inside the Security framework. There is a private
  2648. function that does this, but I don't want to have to explain to you why I
  2649. got your application rejected from the App Store due to the use of a
  2650. private API, so the best we can do is free up our own char array that we
  2651. created way back in darwinssl_connect_step1... */
  2652. Curl_safefree(ptr);
  2653. }
  2654. static size_t Curl_darwinssl_version(char *buffer, size_t size)
  2655. {
  2656. return snprintf(buffer, size, "SecureTransport");
  2657. }
  2658. /*
  2659. * This function uses SSLGetSessionState to determine connection status.
  2660. *
  2661. * Return codes:
  2662. * 1 means the connection is still in place
  2663. * 0 means the connection has been closed
  2664. * -1 means the connection status is unknown
  2665. */
  2666. static int Curl_darwinssl_check_cxn(struct connectdata *conn)
  2667. {
  2668. struct ssl_connect_data *connssl = &conn->ssl[FIRSTSOCKET];
  2669. OSStatus err;
  2670. SSLSessionState state;
  2671. if(BACKEND->ssl_ctx) {
  2672. err = SSLGetSessionState(BACKEND->ssl_ctx, &state);
  2673. if(err == noErr)
  2674. return state == kSSLConnected || state == kSSLHandshake;
  2675. return -1;
  2676. }
  2677. return 0;
  2678. }
  2679. static bool Curl_darwinssl_data_pending(const struct connectdata *conn,
  2680. int connindex)
  2681. {
  2682. const struct ssl_connect_data *connssl = &conn->ssl[connindex];
  2683. OSStatus err;
  2684. size_t buffer;
  2685. if(BACKEND->ssl_ctx) { /* SSL is in use */
  2686. err = SSLGetBufferedReadSize(BACKEND->ssl_ctx, &buffer);
  2687. if(err == noErr)
  2688. return buffer > 0UL;
  2689. return false;
  2690. }
  2691. else
  2692. return false;
  2693. }
  2694. static CURLcode Curl_darwinssl_random(struct Curl_easy *data UNUSED_PARAM,
  2695. unsigned char *entropy, size_t length)
  2696. {
  2697. /* arc4random_buf() isn't available on cats older than Lion, so let's
  2698. do this manually for the benefit of the older cats. */
  2699. size_t i;
  2700. u_int32_t random_number = 0;
  2701. (void)data;
  2702. for(i = 0 ; i < length ; i++) {
  2703. if(i % sizeof(u_int32_t) == 0)
  2704. random_number = arc4random();
  2705. entropy[i] = random_number & 0xFF;
  2706. random_number >>= 8;
  2707. }
  2708. i = random_number = 0;
  2709. return CURLE_OK;
  2710. }
  2711. static CURLcode Curl_darwinssl_md5sum(unsigned char *tmp, /* input */
  2712. size_t tmplen,
  2713. unsigned char *md5sum, /* output */
  2714. size_t md5len)
  2715. {
  2716. (void)md5len;
  2717. (void)CC_MD5(tmp, (CC_LONG)tmplen, md5sum);
  2718. return CURLE_OK;
  2719. }
  2720. static CURLcode Curl_darwinssl_sha256sum(const unsigned char *tmp, /* input */
  2721. size_t tmplen,
  2722. unsigned char *sha256sum, /* output */
  2723. size_t sha256len)
  2724. {
  2725. assert(sha256len >= CURL_SHA256_DIGEST_LENGTH);
  2726. (void)CC_SHA256(tmp, (CC_LONG)tmplen, sha256sum);
  2727. return CURLE_OK;
  2728. }
  2729. static bool Curl_darwinssl_false_start(void)
  2730. {
  2731. #if CURL_BUILD_MAC_10_9 || CURL_BUILD_IOS_7
  2732. if(SSLSetSessionOption != NULL)
  2733. return TRUE;
  2734. #endif
  2735. return FALSE;
  2736. }
  2737. static ssize_t darwinssl_send(struct connectdata *conn,
  2738. int sockindex,
  2739. const void *mem,
  2740. size_t len,
  2741. CURLcode *curlcode)
  2742. {
  2743. /*struct Curl_easy *data = conn->data;*/
  2744. struct ssl_connect_data *connssl = &conn->ssl[sockindex];
  2745. size_t processed = 0UL;
  2746. OSStatus err;
  2747. /* The SSLWrite() function works a little differently than expected. The
  2748. fourth argument (processed) is currently documented in Apple's
  2749. documentation as: "On return, the length, in bytes, of the data actually
  2750. written."
  2751. Now, one could interpret that as "written to the socket," but actually,
  2752. it returns the amount of data that was written to a buffer internal to
  2753. the SSLContextRef instead. So it's possible for SSLWrite() to return
  2754. errSSLWouldBlock and a number of bytes "written" because those bytes were
  2755. encrypted and written to a buffer, not to the socket.
  2756. So if this happens, then we need to keep calling SSLWrite() over and
  2757. over again with no new data until it quits returning errSSLWouldBlock. */
  2758. /* Do we have buffered data to write from the last time we were called? */
  2759. if(BACKEND->ssl_write_buffered_length) {
  2760. /* Write the buffered data: */
  2761. err = SSLWrite(BACKEND->ssl_ctx, NULL, 0UL, &processed);
  2762. switch(err) {
  2763. case noErr:
  2764. /* processed is always going to be 0 because we didn't write to
  2765. the buffer, so return how much was written to the socket */
  2766. processed = BACKEND->ssl_write_buffered_length;
  2767. BACKEND->ssl_write_buffered_length = 0UL;
  2768. break;
  2769. case errSSLWouldBlock: /* argh, try again */
  2770. *curlcode = CURLE_AGAIN;
  2771. return -1L;
  2772. default:
  2773. failf(conn->data, "SSLWrite() returned error %d", err);
  2774. *curlcode = CURLE_SEND_ERROR;
  2775. return -1L;
  2776. }
  2777. }
  2778. else {
  2779. /* We've got new data to write: */
  2780. err = SSLWrite(BACKEND->ssl_ctx, mem, len, &processed);
  2781. if(err != noErr) {
  2782. switch(err) {
  2783. case errSSLWouldBlock:
  2784. /* Data was buffered but not sent, we have to tell the caller
  2785. to try sending again, and remember how much was buffered */
  2786. BACKEND->ssl_write_buffered_length = len;
  2787. *curlcode = CURLE_AGAIN;
  2788. return -1L;
  2789. default:
  2790. failf(conn->data, "SSLWrite() returned error %d", err);
  2791. *curlcode = CURLE_SEND_ERROR;
  2792. return -1L;
  2793. }
  2794. }
  2795. }
  2796. return (ssize_t)processed;
  2797. }
  2798. static ssize_t darwinssl_recv(struct connectdata *conn,
  2799. int num,
  2800. char *buf,
  2801. size_t buffersize,
  2802. CURLcode *curlcode)
  2803. {
  2804. /*struct Curl_easy *data = conn->data;*/
  2805. struct ssl_connect_data *connssl = &conn->ssl[num];
  2806. size_t processed = 0UL;
  2807. OSStatus err = SSLRead(BACKEND->ssl_ctx, buf, buffersize, &processed);
  2808. if(err != noErr) {
  2809. switch(err) {
  2810. case errSSLWouldBlock: /* return how much we read (if anything) */
  2811. if(processed)
  2812. return (ssize_t)processed;
  2813. *curlcode = CURLE_AGAIN;
  2814. return -1L;
  2815. break;
  2816. /* errSSLClosedGraceful - server gracefully shut down the SSL session
  2817. errSSLClosedNoNotify - server hung up on us instead of sending a
  2818. closure alert notice, read() is returning 0
  2819. Either way, inform the caller that the server disconnected. */
  2820. case errSSLClosedGraceful:
  2821. case errSSLClosedNoNotify:
  2822. *curlcode = CURLE_OK;
  2823. return -1L;
  2824. break;
  2825. default:
  2826. failf(conn->data, "SSLRead() return error %d", err);
  2827. *curlcode = CURLE_RECV_ERROR;
  2828. return -1L;
  2829. break;
  2830. }
  2831. }
  2832. return (ssize_t)processed;
  2833. }
  2834. static void *Curl_darwinssl_get_internals(struct ssl_connect_data *connssl,
  2835. CURLINFO info UNUSED_PARAM)
  2836. {
  2837. (void)info;
  2838. return BACKEND->ssl_ctx;
  2839. }
  2840. const struct Curl_ssl Curl_ssl_darwinssl = {
  2841. { CURLSSLBACKEND_DARWINSSL, "darwinssl" }, /* info */
  2842. #ifdef DARWIN_SSL_PINNEDPUBKEY
  2843. SSLSUPP_PINNEDPUBKEY,
  2844. #else
  2845. 0,
  2846. #endif /* DARWIN_SSL_PINNEDPUBKEY */
  2847. sizeof(struct ssl_backend_data),
  2848. Curl_none_init, /* init */
  2849. Curl_none_cleanup, /* cleanup */
  2850. Curl_darwinssl_version, /* version */
  2851. Curl_darwinssl_check_cxn, /* check_cxn */
  2852. Curl_darwinssl_shutdown, /* shutdown */
  2853. Curl_darwinssl_data_pending, /* data_pending */
  2854. Curl_darwinssl_random, /* random */
  2855. Curl_none_cert_status_request, /* cert_status_request */
  2856. Curl_darwinssl_connect, /* connect */
  2857. Curl_darwinssl_connect_nonblocking, /* connect_nonblocking */
  2858. Curl_darwinssl_get_internals, /* get_internals */
  2859. Curl_darwinssl_close, /* close_one */
  2860. Curl_none_close_all, /* close_all */
  2861. Curl_darwinssl_session_free, /* session_free */
  2862. Curl_none_set_engine, /* set_engine */
  2863. Curl_none_set_engine_default, /* set_engine_default */
  2864. Curl_none_engines_list, /* engines_list */
  2865. Curl_darwinssl_false_start, /* false_start */
  2866. Curl_darwinssl_md5sum, /* md5sum */
  2867. Curl_darwinssl_sha256sum /* sha256sum */
  2868. };
  2869. #ifdef __clang__
  2870. #pragma clang diagnostic pop
  2871. #endif
  2872. #endif /* USE_DARWINSSL */